-4

次のようなテーブル値のパラメーターがあります。

CREATE TYPE [dbo].[Loc] AS TABLE(Lo integer)

My Stored Proceurdure は、次のような場所 ID を取得します。

 ALTER PROCEDURE [dbo].[T_TransactionSummary] 
 @startDate datetime,  
 @endDate datetime,
@locations dbo.Loc readonly
..........................
.........................
WHERE     (Transaction_tbl.dtime BETWEEN @fromDate AND @toDate) 
AND  EXISTS (SELECT 1 FROM @locations WHERE lo = Location_tbl.Locid)  

私のlocidフィールドは整数です。このlocidはリストボックスから取得されます.1つのアイテムを選択すると1つのlocidが来ます.2つのアイテムを選択すると2つのlocidが来ます..@locationsパラメーター(整数)を入力するListBoxがあります。リストボックスの値を次のように取りました

cnt = LSTlocations.SelectedItems.Count
  Dim dtlist As New DataTable()
    Dim locid As Integer
    If cnt > 0 Then
        For i = 0 To cnt - 1
            dtlist.Columns.Add(locid, GetType(Integer))
            Dim locationanme As String = LSTlocations.SelectedItems(i).ToString
            locid = RecordID("Locid", "Location_tbl", "LocName", locationanme)
            dtlist.Rows.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
        Dim tvp1 As SqlParameter = cmd23.Parameters.AddWithValue("@locations", dtlist)
         tvp1.SqlDbType = SqlDbType.Structured
         tvp1.TypeName = "dbo.Loc"
        da.SelectCommand = cmd23
        da.Fill(ds)

しかし、私は次のようなエラーが発生しています:

オペランド型の衝突: テーブル型は int と互換性がありません

コードとストアド プロシージャの問題点

4

1 に答える 1

0

おそらく、SqlCommand を作成するときに、ストアド プロシージャの最初の 2 つのパラメーター (@startdate、@enddate) を指定しなかったことが原因です。

于 2013-10-30T12:50:30.863 に答える