誰もがDateTime
という値を嫌うようです。DateTime値の形式を変更する
私のプロジェクトでは、SQL SELECT
クエリを使用して、パラメータ値と一致するデータベース内の結果を検索しています。
私が持っているコードは次のとおりです。
Dim where As String = "WHERE [Supp_Code] = @scode " & _
"AND [DateFrom] = @datfrom " & _
"AND [DateTo] = @datto " & _
"AND [Comm_Code] = @ccode " & _
"AND [Customer_Code] = @custcode "
Dim sql As String = "SELECT [Comm_Code], [AqYear] FROM [Acquisition Commission] "
sql &= where & " ORDER BY [AqYear] ASC"
Dim cmd As New OleDb.OleDbCommand(sql, con)
cmd.Parameters.AddWithValue("@scode", cmbSupp.Text.Trim)
cmd.Parameters.AddWithValue("@datfrom", datFrom.Value)
cmd.Parameters.AddWithValue("@datto", datTo.Value)
cmd.Parameters.AddWithValue("@ccode", txtCommCode.Text)
cmd.Parameters.AddWithValue("@custcode", cmbCustomerCode.Text)
Dim daYear As New OleDb.OleDbDataAdapter(cmd)
Dim dsYear As New DataSet
daYear.Fill(dsYear)
コード自体は全く問題がありません。問題は、DateTime
の形式がDateTimePicker
(DateTimePicker
)のDateTime
(これはDateTimePicker
)ですが、データベースには 'dd/MM/yyyy'という名前で格納されているため、DataSet
には0行しか格納されません。
パラメータとして使用する前に、正しいデータベース形式に変換する最も簡単な方法は何ですか?以下のコメント/解答を使用して
EDIT
、私は次のように私のコードを適応してきました:
Dim test As DateTime
Dim test2 As DateTime
test = ugDates.ActiveRow.Cells("DateFrom").Value
test = ugDates.ActiveRow.Cells("DateTo").Value
Try
Dim where As String = "WHERE [Supp_Code] = @scode " & _
"AND [DateFrom] = @datfrom " & _
"AND [DateTo] = @datto " & _
"AND [Comm_Code] = @ccode " & _
"AND [Customer_Code] = @custcode "
Dim sql As String = "SELECT DISTINCT [Comm_Code], [AqYear] FROM [Acquisition Commission] "
sql &= where & " ORDER BY [AqYear] ASC"
Dim cmd As New OleDb.OleDbCommand(sql, con)
cmd.Parameters.Add("@scode", OleDbType.VarChar).Value = cmbSupp.Text
cmd.Parameters.Add(New OleDbParameter("@datfrom", OleDbType.Date).Value = test)
cmd.Parameters.Add(New OleDbParameter("@datto", OleDbType.Date).Value = test2)
cmd.Parameters.Add("@ccode", OleDbType.VarChar).Value = txtCommCode.Text
cmd.Parameters.Add("@custcode", OleDbType.VarChar).Value = cmbCustomerCode.Text
しかし、それは私の二番目のパラメータに次のエラーを与える:
OleDbParameterCollectionは、Booleanオブジェクトではなく、null以外のOleDbParameter型オブジェクトのみを受け入れます。
datFrom.ToString( "dd/MM/yyyy")で十分でしょうか? –
[AddWithValue()の使用を中止できますか?](http://blogs.msmvps.com/jcoehoorn/blog/2014/05/12/can-we-stop-using-addwithvalue-already/) –
日付列は日付列型を使用します(varchar/stringは使用しません)。 –