查看LINQ Expression編譯後的SQL語法(转)
在用了LINQ語法之後的一個月,我幾乎把SQL語法全部拋到腦後了,不過
LINQ好用歸好用,但是實際上操作資料庫的還是SQL語法,如果不知道LINQ語法
編譯過後產生怎樣的SQL語法,一不小心效能就會變差,所以今天來記錄三種查詢
LINQ所轉換的SQL語法。
第一種:
參考自:ADO.Net Entity Framework : (一) 查詢執行時的SQL語法
第一種方法應該只適用在Entity Framework,Linq to Sql有沒有這個或類似的方法我還沒去試
1 |
NorthwindEntities db = new NorthwindEntities(); |
2 |
var category = db.Customers.Where(p => p.CompanyName.Contains("B")) as ObjectQuery; |
3 |
return Content(category.ToTraceString()); |
範例我是用北風資料庫的Customers資料表,然後將查詢語句轉成ObjectQuery
命名空間:using System.Data.Objects;
MSDN資料:http://msdn.microsoft.com/zh-tw/library/system.data.objects.objectquery.aspx
就可以利用ToTraceString() 方法來將語法轉換成SQL語法
(我的範例是用MVC做的,所以我直接return Content(SQL語法)) 結果如下:
![]()
第二種:
利用SQL Profiler來查詢執行時的SQL語法
首先可以在SQL Server Management Studio的工具中找到SQL Server Profiler
![]()
點左上角的新增追蹤
![]()
在事件選取範圍頁籤中可以設定要查詢的資料
![]()
如果想更精確的鎖定監看某個資料庫,可以點"顯示所有資料行" 然後點"資料行篩選"
![]()
點選左邊的DatabaseName,然後點開右邊的類似,我要監看的是Northwind資料庫,就輸入Northwind
![]()
然後將程式碼改成:
1 |
NorthwindEntities db = new NorthwindEntities(); |
2 |
var category = db.Customers.Where(p => p.CompanyName.Contains("B")); |
3 |
return View(category); |
程式執行時,就可以在SQL Profiler中抓到對SQL Server所下達的指令
![]()
另外這邊提供一個小技巧,在web.config的連線字串中,加入一小段話:
![]()
在連線字串的後面 加上 ;Application Name=”XXX”,之後用SQL Profiler的時候就可以看到
![]()
ApplicationName的欄位中有設定的名字,這可以幫助在查詢時很快的知道是從哪下達的指令。
第三種方法:
是利用LINQPad這個軟體來查詢
下載回來執行之後,有很多種使用方式,我這邊就直接用我建立的edmx檔來操作
在左邊選新增連線
![]()
然後選擇用自己的data context ,我用的是entity framework
![]()
接著選擇檔案,按Browse,選自己專案底下的bin資料夾中的.dll檔
![]()
他就會找出組件中所建立的edmx![]()
設定完之後,就會看到我們建立的edmx所拉的table出現在左邊的框框中
![]()
接著呢,就直接在右邊下語法,就可以看到結果,也可以看到SQL指令囉
![]()
![]()
查看LINQ Expression編譯後的SQL語法(转)的更多相关文章
- SQL 語法
查詢 Sql = ("SELECT A1, A2, A5, A4 FROM Table1 ") 筆數 Sql = ("Select COUNT(*) From TW01. ...
- 查看Linq to Sql生成的sql语句(转)
查看Linq to Sql生成的sql语句 在控制台项目中,比较简单,直接db.Log = Console.Out;就OK了 但是在其他项目中,需要处理如下: StreamWriter sw = ...
- [LINQ2Dapper]最完整Dapper To Linq框架(五)---查看Linq实际执行的SQL
此例子是使用LINQ2Dapper封装,效率优于EntityFramwork,并且支持.NetFramework和.NetCore框架,只依赖于Dapper支持.net framework4.6.1及 ...
- MAC下反編譯安卓APK
所需工具: 1.apktool http://ibotpeaches.github.io/Apktool/ (配置說明) https://bitbucket.org/iBotPeac ...
- [Linq Expression]练习自己写绑定
源代码:TypeMapper.zip 背景 项目中,我们会经常用到各种赋值语句,比如把模型的属性赋值给UI,把视图模型的属性拷贝给Entity.如果模型属性太多,赋值也会变成苦力活.所以,框架编程的思 ...
- CentOS 7 編譯qBittorrent Web UI安裝指南
前言 以下是安装qBittorrent教学. 适用于CentOS7或更新版本 适用于qBittorrent4.1.5或更新版本 安裝須知 qBittorrent基于libtorrent,所以必须先安装 ...
- 【转】編譯Ogre1.9 IOS Dependencies及Ogre Source步驟及相關注意事項…
http://makedreamvsogre.blogspot.tw/2014/01/ios-dependenciesogre-source.html 可能有人會想問我為什麼要自行編譯IOS Depe ...
- llvm學習(二)————llvm編譯與環境構建
本文由博主原创,转载请注明出处(保留此处和链接): IT人生(http://blog.csdn.net/robinblog/article/details/17339027) 在2011十月份的时候, ...
- C 語言中的編譯指示 (Pragma)
編譯指示 #pragma 是用來告知編譯器某些特殊指示,例如不要輸出錯誤訊息,抑制警告訊息,或者加上記憶體漏洞檢查機制等.這些指示通常不是標準的 C 語言所具備的,而是各家編譯器廠商或開發者所制定的, ...
随机推荐
- 懒人的福利?教你用set维护斜率优化凸包
斜率优化题目大家肯定都做得不少了,有一些题目查询插入点的x坐标和查询斜率都不单调,这样就需要维护动态凸包并二分斜率.(例如bzoj1492) 常规的做法是cdq分治或手写平衡树维护凸包,然而如果我不愿 ...
- [NOIp2003提高组]神经网络
OJ题号:洛谷1038 思路:拓扑排序,注意细节.1.题目中求和运算$C_i=\displaystyle{\sum_{(j,i)\in E}W_{ji}C_j-U_i}$中$U_i$在求和运算外,只要 ...
- COGS NIOP联赛 图论相关算法总结
最小生成树 Kruskal+ufs int ufs(int x) { return f[x] == x ? x : f[x] = ufs(f[x]); } int Kruskal() { int w ...
- SWD 接口电路
- nginx源码学习 资料
首先要做的当然是下载一份nginx源码,可以从nginx官方网站下载一份最新的. 看了nginx源码,发现这是一份完全没有注释,完全没有配置文档的代码. 现在你最希望要的是一份注释版的nginx源码, ...
- delphi 启动停止windows服务 转
http://blog.csdn.net/haiou327/article/details/6106233 不用cmd用delphi如何实现启动停止windows服务建议参考一下Delphi的Sckt ...
- c# 主机和网络字节序的转换 关于网络字节序和主机字节序的转换
最近使用C#进行网络开发,需要处理ISO8583报文,由于其中有些域是数值型的,于是在传输的时候涉及到了字节序的转换. 字节顺序是指占内存多于一个字节类型的数据在内存中的存放顺序,通常有两种字节顺序, ...
- delphi实现数字签名
上周,另一部门需要支援解决数字签名问题.但因为之前也没做过,现学现卖.此方面可参考的中文资料较少,特作分享,方便查阅. 上周,另一部门需要支援解决数字签名问题.但因为之前也没做过,现学现卖.此方面可参 ...
- iOS App与iTunes文件传输的方法和对iOS App文件结构的说明
转:http://www.xiaoyaoli.com/?p=368 就像很多iOS上面的播放器App一样,本文编写一个程序可以通过iTunes往里面放文件,比如编写一个音乐播放器程序,通过itune往 ...
- [CALayer release]: message sent to deallocated instance
遇到此问题时,查看以下类的dealloc方法中是否有过度释放. 可以在release前先判断以下对象是否还存在. -(void)dealloc { if (!m_tableView) [m_table ...