C# と VB.NET の質問掲示板

ASP.NET、C++/CLI、Java 何でもどうぞ

ログ内検索
  • キーワードを複数指定する場合は 半角スペース で区切ってください。
  • 検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
  • [返信]をクリックすると返信ページへ移動します。
キーワード/ 検索条件 /
検索範囲/ 強調表示/ ON (自動リンクOFF)
結果表示件数/ 記事No検索/ ON
大文字と小文字を区別する

No.91634 の関連記事表示

<< 0 >>
■91634  Re[4]: SQLServerのSQLがわかりません。
□投稿者/ 韋駄天 -(2019/07/16(Tue) 14:54:13)
    No91631 (魔界の仮面弁士 さん) に返信
    > ■No91628 (韋駄天 さん) に返信
    
    ありがとうございました。
    CROSS APPLY で
    検索したら以下のが見つかりました。
    少し違うのですが
    
    StudentID	FirstName	LastName	Birthday		Gender	TestIDList
    1		Taro		Yamada		1980-02-15 00:00:00.000	M	1,2
    2		Hanako		Tanaka		1979-12-30 00:00:00.000	F	1
    3		Yuko		Suzuki		1979-07-07 00:00:00.000	F	NULL
    4		Takao		Sato		1980-03-12 00:00:00.000	M	3
    5		Hiroki		Takagi		1979-04-05 00:00:00.000	M	1,2,3
    6		Yuka		Kimura		1981-03-27 00:00:00.000	F	2
    
    このデータテーブルで
    
    SELECT  * 
    FROM    T_Student AS S
    CROSS APPLY dbo.ufnStringSplit(TestIDList); 
    
    を実行すると
    
    StudentID	FirstName	LastName	Birthday		Gender	TestIDList	Value
    1		Taro		Yamada		1980-02-15 00:00:00.000	M	1,2		1
    1		Taro		Yamada		1980-02-15 00:00:00.000	M	1,2		2
    2		Hanako		Tanaka		1979-12-30 00:00:00.000	F	1		1
    4		Takao		Sato		1980-03-12 00:00:00.000	M	3		3
    5		Hiroki		Takagi		1979-04-05 00:00:00.000	M	1,2,3		1
    5		Hiroki		Takagi		1979-04-05 00:00:00.000	M	1,2,3		2
    5		Hiroki		Takagi		1979-04-05 00:00:00.000	M	1,2,3		3
    6		Yuka		Kimura		1981-03-27 00:00:00.000	F	2		2
    
    なので、Value を TestIDList と置き換えれば出来上がりですね。
    
    WITHの中身が少し理解できませんが、たぶんXMLを使用してカンマで分割しているのだと思います。
    XMLを使用する方法も見たのですが、使ったことがないので理解できませんでした。
    もう少し勉強します。
    
    CrossApply を使うとできることがわかってよかったです。
    
    
    
記事No.91620 のレス / END /過去ログ158より / 関連記事表示
削除チェック/



<< 0 >>

パスワード/

- Child Tree -