T-SQLの小技?を一つ。
MySQLでは、以下のようにSELECT文にLIMIT句を指定して、クエリ結果から指定オフセットから指定件数分取得することが可能。
SELECT ・・・ FROM TABLE_NAME ・・・ LIMIT 10,5 -- クエリ結果の5行目から10行分
-- または
SELECT ・・・ FROM TABLE_NAME ・・・ LIMIT 10 OFFSET 5 -- クエリ結果の5行目から10行分ではT-SQLで同じ事を行なう場合はどうすれば良いのか?
昔はスマートなやり方はなかったが、SQL Server 2012からは以下の構文で取得が可能となったようだ。(但し、ORDER BY句の一部だが・・・)
-- クエリ結果の@START_OFFSET行目から@FETCH_NUMBER行分取得
SELECT COLUMN_1[,COLUMN_2[,...]] FROM TABLE_NAME
・・・
ORDER BY KEY_COLUMN
OFFSET @START_OFFSET ROWS
FETCH NEXT @FETCH_NUMBER ROWS ONLY※↓EFでSQL Serverに対して.Skipや.Takeを使用すると、上記と同様なSQLが作成された。
var q = ctx.TABLE_NAME.OrderBy(v=>v.KEY_COLUMN).Skip(n).Take(m);SELECT ・・・
FROM TABLE_NAME AS [T]
ORDER BY [T].[KEY_COLUMN]
OFFSET @__p_0 ROWS FETCH NEXT @__p_1 ROWS ONLYこれって結構使う機能だと思うのだけど、T-SQLでサポートされていたとは知らなかった(^^;





Users Today : 40
Users Yesterday : 44
Users Last 7 days : 183
Users Last 30 days : 964
Users This Month : 843
Users This Year : 15669
Total Users : 93473
Views Today : 59
Views Yesterday : 53
Views Last 7 days : 241
Views Last 30 days : 1232
Views This Month : 1059
Views This Year : 21264
Total views : 131199
Who's Online : 1
ちなみに、EFクエリでTakeだけだと、
“SELECT TOP n ・・・”
Skipだけだと、
“・・・ORDERBY KEY_COLUMN OFFSET n ROWS”
が生成されるようだ。
EFクエリに.OrderByを付けない場合はログ上にはWarningが吐かれ、下記のようなSQLとなった。
SELECT ・・・
FROM [TABLE_NAME] AS [T]
ORDER BY (SELECT 1)
OFFSET @__p_0 ROWS FETCH NEXT @__p_1 ROWS ONLY