次のようなストアド プロシージャがあります。
ALTER PROCEDURE [dbo].[T_TransactionSummary]
@startDate datetime,
@endDate datetime,
@locations integer
AS
BEGIN
.................
................
WHERE (Transaction_tbl.dtime BETWEEN @fromDate AND @toDate)
AND (Location_tbl.Locid IN (@locations))
@locations パラメーター (整数) を設定する ListBox と、そのための 2 つの DateTimePicker コントロールがあり@fromDate
、@toDate.
リストボックスの値を次のように取得しました。
cnt = LSTlocations.SelectedItems.Count
Dim list As New List(Of Integer)
Dim locid As Integer
If cnt > 0 Then
For i = 0 To cnt - 1
Dim locationanme As String = LSTlocations.SelectedItems(i).ToString
locid = RecordID("Locid", "Location_tbl", "LocName", locationanme)
list.Add(locid)
Next
End If
Dim da As New SqlDataAdapter
Dim ds As New DataSet
Dim cmd23 As New SqlCommand("T_TransactionSummary", con.connect)
cmd23.CommandType = CommandType.StoredProcedure
cmd23.Parameters.Add("@startDate", SqlDbType.NVarChar, 50, ParameterDirection.Input).Value = startdate
cmd23.Parameters.Add("@endDate", SqlDbType.NVarChar, 50, ParameterDirection.Input).Value = enddate
cmd23.Parameters.Add("@locations", SqlDbType.Int).Value = String.Join(",", list)
da.SelectCommand = cmd23
da.Fill(ds)
コードがここに到達すると、次のようなエラーが発生します。
「パラメータ値を文字列から Int32 に変換できませんでした
私はこの行でエラーが発生していることを知っています
cmd23.Parameters.Add("@locations", SqlDbType.Int).Value = String.Join(",", list)
私はvb.netを使用しています。私のコードの何が問題なのですか..どんな助けでも大歓迎です..