在程序中書(shū)寫(xiě)SQL語(yǔ)句_.Net教程
推薦:ASP.Net常用功能整理--生成圖片的縮略圖這二天想了想決定把自己先前做的項(xiàng)目中的小的功能,整理一下,奉獻(xiàn)大家!經(jīng)大家提議,我決定加上源代碼,但是源代碼不一定都是我寫(xiě)的,有的來(lái)自書(shū)上,有的來(lái)自網(wǎng)上,有的來(lái)自開(kāi)源項(xiàng)目,與我
園子里關(guān)于存儲(chǔ)過(guò)程的討論有很多,不少人建議將SQL語(yǔ)句寫(xiě)在程序中,這篇隨筆討論一下SQL語(yǔ)句在程序中的寫(xiě)法。
1string strSQL = "SELECT [AddressID], [AddressLine1], [AddressLine2], [City], [StateProvinceID], [PostalCode], [rowguid], [ModifiedDate] FROM [AdventureWorks].[Person].[Address] WHERE City = 'Bothell' ORDER BY AddressID";
這是最普通的一種寫(xiě)法,而且在開(kāi)發(fā)中被廣泛采用。
string strSQL = "SELECT "
"[AddressID], "
"[AddressLine1], "
"[AddressLine2], "
"[City], "
"[StateProvinceID], "
"[PostalCode], "
"[rowguid], "
"[ModifiedDate] "
"FROM "
"[AdventureWorks].[Person].[Address] "
"WHERE "
"City = 'Bothell' "
"ORDER BY "
"AddressID";
第二種寫(xiě)法,除了讓人開(kāi)著舒服一點(diǎn)外,沒(méi)有任何好處。
上圖所示的寫(xiě)法要更好一點(diǎn),可以降低維護(hù)難度,提高開(kāi)發(fā)效率,團(tuán)隊(duì)開(kāi)發(fā)中應(yīng)該對(duì)這些小細(xì)節(jié)加以規(guī)定。其中,圖中標(biāo)示的第一點(diǎn)可以看看在SQL Server 2005中通過(guò)下圖菜單生成的SQL語(yǔ)句,但不知道為什么SQL Server 2005的查詢(xún)編輯器生成的SQL語(yǔ)句還是那么蹩腳。微軟完全可以解析SQL語(yǔ)句并使之成為更有利于開(kāi)發(fā)的格式。

上圖所示的寫(xiě)法要更好一點(diǎn),可以降低維護(hù)難度,提高開(kāi)發(fā)效率,團(tuán)隊(duì)開(kāi)發(fā)中應(yīng)該對(duì)這些小細(xì)節(jié)加以規(guī)定。其中,圖中標(biāo)示的第一點(diǎn)可以看看在SQL Server 2005中通過(guò)下圖菜單生成的SQL語(yǔ)句,但不知道為什么SQL Server 2005的查詢(xún)編輯器生成的SQL語(yǔ)句還是那么蹩腳。微軟完全可以解析SQL語(yǔ)句并使之成為更有利于開(kāi)發(fā)的格式。

如果有兩個(gè)表進(jìn)行連接,INNER(LEFT/RIGHT) JOIN等語(yǔ)句也應(yīng)該寫(xiě)在一行。另外,建議使用更簡(jiǎn)單的英文別名代替中文表名。
分享:C#中連接兩個(gè)DataTable,相當(dāng)于Sql的InnerJoin在下面的例子中實(shí)現(xiàn)了3個(gè)Join方法,其目的是把兩個(gè)DataTable連接起來(lái),相當(dāng)于Sql的Inner Join方法,返回DataTable的所有列。 如果兩個(gè)DataTable中的DataColumn有重復(fù)的話(huà),把第二個(gè)設(shè)置
- asp.net如何得到GRIDVIEW中某行某列值的方法
- .net SMTP發(fā)送Email實(shí)例(可帶附件)
- js實(shí)現(xiàn)廣告漂浮效果的小例子
- asp.net Repeater 數(shù)據(jù)綁定的具體實(shí)現(xiàn)
- Asp.Net 無(wú)刷新文件上傳并顯示進(jìn)度條的實(shí)現(xiàn)方法及思路
- Asp.net獲取客戶(hù)端IP常見(jiàn)代碼存在的偽造IP問(wèn)題探討
- VS2010 水晶報(bào)表的使用方法
- ASP.NET中操作SQL數(shù)據(jù)庫(kù)(連接字符串的配置及獲取)
- asp.net頁(yè)面?zhèn)髦禍y(cè)試實(shí)例代碼
- DataGridView - DataGridViewCheckBoxCell的使用介紹
- asp.net中javascript的引用(直接引入和間接引入)
- 三層+存儲(chǔ)過(guò)程實(shí)現(xiàn)分頁(yè)示例代碼
- 相關(guān)鏈接:
- 教程說(shuō)明:
.Net教程-在程序中書(shū)寫(xiě)SQL語(yǔ)句
。