亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

LINQ to SQL:處理char(1)字段的方式會引起全表掃描問題

2024-08-31 01:00:05
字體:
來源:轉載
供稿:網友

LINQ to SQL:處理char(1)字段的方式會引起全表掃描問題

 

如果表中的字段類型為 char(1) 時,Linq to SQL生成char (System.Char)的屬性,如下圖

LINQ to SQL:處理char(1)字段的方式會引起全表掃描問題

LINQ to SQL:處理char(1)字段的方式會引起全表掃描問題

表定義生成的實體

2.

如果要查詢LineCode=='A'的記錄,可以這樣定義Linq查詢語句

var test1 = from p in db.ProductLines

            where p.LineCode =='A'

            select p;

生成的SQL語句是這樣的

SELECT [t0].[LineCode], [t0].[LineName], [t0].[JPH], [t0].[QueueCount]

FROM [dbo].[ProductLine] AS [t0]

WHERE UNICODE([t0].[LineCode]) = @p0

-- @p0: Input Int (Size = 0; Prec = 0; Scale = 0) [65]

-- Context: SqlProvider(Sql2000) Model: AttributedMetaModel Build: 3.5.21022.8

注意到Where語句了嗎?是WHERE UNICODE([t0].[LineCode]) = 65,這里先取LineCode列內容的UNICODE再和'A'的UNICODE比較。我們知道'A'和'a'的UNICODE是不同的。UNICODE('A') =65,UNICODE('a')=97,也就是說,我們在Linq to SQL中這二個查詢的結果是不一樣的。

Linq 語句

var test1 = from p in db.ProductLines

            where p.LineCode =='a'

            select p;

var test1 = from p in db.ProductLines

            where p.LineCode =='A'

            select p;

生成SQL語句

SELECT [t0].[LineCode], [t0].[LineName], [t0].[JPH], [t0].[QueueCount]

FROM [dbo].[ProductLine] AS [t0]

WHERE UNICODE([t0].[LineCode]) = @p0

-- @p0: Input Int (Size = 0; Prec = 0; Scale = 0) [97]

SELECT [t0].[LineCode], [t0].[LineName], [t0].[JPH], [t0].[QueueCount]

FROM [dbo].[ProductLine] AS [t0]

WHERE UNICODE([t0].[LineCode]) = @p0

-- @p0: Input Int (Size = 0; Prec = 0; Scale = 0) [65]

明顯,在Linq to sql是查詢char(1)類型字段是區分大小寫的。

這還會導致一個比較嚴重的問題,我們知道在SQL Server中,任何在運算符左邊的操作都會使SQL采用全表掃描。也就是說,Linq的這個查詢,會引起全表掃描,即使[LineCode]列上定義了聚合索引。而如果是where [linecode]='A',則可以使用索引。我們看下這二種情況時的查詢執行計劃對比。

LINQ to SQL:處理char(1)字段的方式會引起全表掃描問題

圖中可以看出,Linq to SQL 生成的SQL語句是表掃描,而后者則是索引查找。

 

3.

對策

在DBML設計器中將LineCode改成string類型。

LINQ to SQL:處理char(1)字段的方式會引起全表掃描問題

看一下改了之后的查詢

var test1 = from p in db.ProductLines

            where p.LineCode == "a"

            select p;

SELECT [t0].[LineCode], [t0].[LineName], [t0].[JPH], [t0].[QueueCount]

FROM [dbo].[ProductLine] AS [t0]

WHERE [t0].[LineCode] = @p0

-- @p0: Input VarChar (Size = 1; Prec = 0; Scale = 0) [a]

-- Context: SqlProvider(Sql2000) Model: AttributedMetaModel Build: 3.5.21022.8

Linqsql

改為string后,生成的SQL不再用UNICODE函數了,就解決了區分大小寫和引起全表掃描的問題。但又引起一個新的問題,因為數據庫中存儲的數據長度是1,在Insert和Update時就要注意,LineCode不要輸入過長的內容,否則會出錯了。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品偷伦免费视频观看的| 国产精品成av人在线视午夜片| 在线视频欧美日韩| 午夜精品福利电影| 亚洲精品电影网在线观看| 久久免费国产精品1| 国产综合在线观看视频| 欧美亚洲第一区| 欧美最猛性xxxxx(亚洲精品)| 国产一区二区三区在线免费观看| 日韩有码在线播放| xxav国产精品美女主播| 亚洲高清免费观看高清完整版| 亚洲韩国日本中文字幕| 亚洲色图13p| 国产精品久久电影观看| 欧美亚洲成人免费| 亚洲天堂av网| 亚洲第一精品自拍| 国产专区欧美专区| 91亚洲va在线va天堂va国| 国产精品久久久久久久久久久久久久| 亚洲免费精彩视频| 国产亚洲欧美日韩精品| 国产精品久久久久久久久免费| 久久久91精品国产| 色午夜这里只有精品| 日韩亚洲在线观看| 在线观看久久久久久| 久久影院模特热| 成人免费在线视频网址| 91av中文字幕| www亚洲精品| 国产精品手机播放| 91免费的视频在线播放| 欧美成人激情图片网| 久久夜精品va视频免费观看| 久久中文字幕在线视频| 九九九久久久久久| 日韩精品免费一线在线观看| 亚洲福利视频二区| 欧美激情视频网| 久久视频在线直播| 97久久精品人人澡人人爽缅北| 亚洲欧洲xxxx| 亚洲欧美国产精品va在线观看| 国产精品入口日韩视频大尺度| 91wwwcom在线观看| 在线a欧美视频| 国产成人精品免费视频| 亚洲精选一区二区| 久久免费视频这里只有精品| 国产精品久久久久久久午夜| 欧美夫妻性生活视频| 欧美日韩免费观看中文| 亚洲成人av在线| 日韩小视频网址| 亚洲一区二区在线播放| 久久久999精品视频| 国产91|九色| 这里精品视频免费| 成人午夜激情网| 一区二区三区视频观看| 欧美激情成人在线视频| 91久久久国产精品| 国产精品一区二区电影| 日韩在线免费视频| 欧美成人免费观看| 69视频在线免费观看| 亚洲男人天堂2023| 亚洲日韩中文字幕| 91中文字幕一区| 成人看片人aa| 日韩免费观看在线观看| 亚洲国内精品视频| 国产在线观看一区二区三区| 日韩二区三区在线| 国产在线播放不卡| 97国产suv精品一区二区62| 成人欧美在线观看| 国产精品视频一区国模私拍| 国产成人啪精品视频免费网| 51精品国产黑色丝袜高跟鞋| 欧美日韩亚洲视频一区| 97av在线视频免费播放| 国产精品久久久久久久天堂| 亚洲精品国产综合区久久久久久久| 日韩va亚洲va欧洲va国产| 欧美激情视频在线免费观看 欧美视频免费一| 亚洲成av人片在线观看香蕉| 欧美一二三视频| 高跟丝袜一区二区三区| 国产精品久久婷婷六月丁香| 色综合视频网站| 成人免费看吃奶视频网站| 精品久久久久久久中文字幕| 日韩激情视频在线| 成人激情视频在线播放| 午夜欧美大片免费观看| 亚洲第一免费播放区| 久久久精品免费视频| 久久男人资源视频| 欧美日韩国产91| 国产成人精品免高潮在线观看| 日韩视频免费中文字幕| 91av在线国产| 97久久精品国产| 91亚洲精品在线| 欧美成人精品xxx| 国产精品国产福利国产秒拍| 欧美高清性猛交| 亚洲一区久久久| 668精品在线视频| 国产成人高清激情视频在线观看| 热re91久久精品国99热蜜臀| 国产999视频| 亲子乱一区二区三区电影| 成人激情电影一区二区| 91精品视频在线免费观看| 91伊人影院在线播放| 国产大片精品免费永久看nba| 久久人人爽人人爽人人片av高请| 欧美高清视频在线| 日韩女优在线播放| 中文字幕成人在线| 最新中文字幕亚洲| 91在线观看免费| 91精品国产91久久久久久最新| 欧美日韩国产综合新一区| 欧美国产日韩一区二区在线观看| 国产三级精品网站| 欧美日韩亚洲系列| 日韩成人激情在线| 亚洲欧美在线磁力| 久久九九全国免费精品观看| 欧美黑人一区二区三区| 亚洲精品suv精品一区二区| 少妇高潮久久久久久潘金莲| 日韩综合视频在线观看| 51视频国产精品一区二区| 欧美夫妻性生活视频| 一本色道久久88综合亚洲精品ⅰ| 日韩av综合中文字幕| 欧美精品一区二区三区国产精品| 91在线观看免费观看| 国产成人97精品免费看片| 国产精品三级在线| 日本久久久a级免费| 精品国产区一区二区三区在线观看| 国产精品视频网址| 国产成人一区三区| 秋霞av国产精品一区| 日本精品va在线观看| 国产z一区二区三区| 亚洲欧美日韩天堂一区二区| 国产乱人伦真实精品视频| 日韩av一卡二卡| 久久97久久97精品免视看| 中文字幕精品视频| 国产欧美一区二区白浆黑人| 青青久久av北条麻妃海外网| 久久精品99国产精品酒店日本| 久久精品99无色码中文字幕| 色妞欧美日韩在线|