-1

次のようなテーブル値パラメーターを作成しました。

CREATE TYPE dbo.ss AS TABLE(ss1 integer);

次に、ストアドプロシージャを次のように書きました。

ALTER PROCEDURE [dbo].[T_TransactionSummary] 
 @locations dbo.ss readonly
as
begin
...............
.............
AND (Location_tbl.Locid IN (select ss1 from @locations))  

私の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
        da.SelectCommand = cmd23
        da.Fill(ds) 

しかし、エラーが発生しています: 対応するユーザー定義のテーブル型に 1 列が必要な場合に、2 列のテーブル値パラメーターを渡そうとしています。

4

1 に答える 1

4

LocIDが整数の場合、テーブル タイプは次のようになります。

CREATE TYPE dbo.ss AS TABLE(ss1 INT);
--------------------------------^^^

一体何のためにここを使っているのNVARCHAR(5)ですか?さまざまな理由で意味がありません。

また、コンマ区切りの文字列に結合された整数のリストとして場所のセットを渡すのをやめる必要があります。テーブル値パラメーターは、 のような構造化セットを想定していますDataTable

于 2013-10-21T18:18:02.563 に答える