0

Sessionリストであるがあり、データベースから、に存在する値をint持つ行のみを取得するクエリを作成する必要があります。PKSession

関数を使ってそれを行うINか、セッションからの1つの列と値を使用して新しいデータテーブルを作成し、二重結合を行うことを考えていました。おそらく残っています...

リストからテーブルを作成する方法がわかりません。

私がこれまでに持っているもの:

String ConnString = "Data Source=BRACO-PC\SQL1;Initial Catalog=DiplomskiSQL1SQL;Integrated Security=True";
SqlConnection Conn = new SqlConnection(ConnString);
Conn.Open();
DataTable ukosarici = new DataTable();
SqlDataAdapter da = new SqlDataAdapter("Select Proizvodi.ime, TipProizvoda.tip, Proizvodi.dimenzije, Proizvodi.cijena from Proizvod LEFT JOIN TipProizvoda On Proizvod.tip=TipProizvoda.id_t WHERE Proizvod.id_p IN ", Conn);
SqlCommandBuilder cmd = new SqlCommandBuilder(da);
da.Fill(ukosarici);
GridView1.DataSource = ukosarici;
GridView1.DataBind();
Conn.Close();
4

3 に答える 3

0

これを行う方法はたくさんありますが、私の好みの方法の 1 つは、リストを CSV にシリアル化することです (例: '1,3,5,33')。次に、カスタム SQL テーブル関数を使用してリストをデシリアライズし、データベースでフィルター処理します。

SELECT * FROM mytable t
JOIN dbo.ufn_CSVtoTextList('1,3,5,33' , ',') csv
ON csv.[Entry] = t.Id 

ufn_CSVtoTextList 関数のCREATEスクリプトは次のとおりです。

CREATE FUNCTION [dbo].[ufn_CSVToTextlist] ( @StringInput nVARCHAR(max) ,@SepChar nchar(1) = ',')
RETURNS @OutputTable TABLE ( [Entry] nVarchar(255), [index] int identity (0,1) )
AS
BEGIN

    DECLARE @Entry   nVarChar(255)

    WHILE LEN(@StringInput) > 0
    BEGIN
        SET @Entry      = LEFT(@StringInput, 
                                ISNULL(NULLIF(CHARINDEX(@SepChar, @StringInput) - 1, -1),
                                LEN(@StringInput)))
        SET @StringInput = SUBSTRING(@StringInput,
                                     ISNULL(NULLIF(CHARINDEX(@SepChar, @StringInput), 0),
                                     LEN(@StringInput)) + 1, LEN(@StringInput))

        INSERT INTO @OutputTable ( [Entry] )
        VALUES ( @Entry )
    END

    RETURN
END
于 2012-09-06T14:05:31.027 に答える
0

次のように SqlDataAdapter Call を変更してみてください

 List<int> list ; // Assign with your session int list values
            List<string> l2 = list.ConvertAll<string>(delegate(int i) { return i.ToString(); });
            string query = "Select Proizvodi.ime, TipProizvoda.tip, Proizvodi.dimenzije, Proizvodi.cijena from Proizvod LEFT JOIN TipProizvoda On Proizvod.tip=TipProizvoda.id_t WHERE Proizvod.id_p IN (";
            query = query + string.Join(",", l2.ToArray()) + ")";
            SqlDataAdapter da = new SqlDataAdapter(query, Conn);
于 2012-09-06T14:07:37.753 に答える
0

INSERT一時テーブルまたはテーブル変数を作成し、またはを使用して int を挿入BULK INSERTし、SQL クエリで結合を実行してから、一時テーブルまたはテーブル変数を削除します。

于 2012-09-06T13:57:30.877 に答える