国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

SQL Artisan多層查詢條件嵌套功能

2024-07-21 02:31:40
字體:
來源:轉載
供稿:網友

在實際開發過程中我們經常面對一些查詢或統計子表信息,對于一層處理還是比較簡單,如果二層、三層等或更多時這個時候編寫出來的條件就比較復雜和容易出現編寫錯誤的情況。SQL Artisan字段對象除了提供靈活的比較運算功能外,對象的In方法還提供N層條件嵌套的功能,讓你在構造查詢條件更靈活。

以MSSQL的NorthWind為例:

查詢指定雇員在某段時間的銷售金額。

處理的表:Employees,Orders,Order Details

在實現過程可以通過表關聯查詢或直接對目標表進行查詢,對目標表直接進行查詢就必須把父表的條件以嵌套的方式添加到當前查詢條件中。

Employee.Employee->Orders.OrderDate-> Sum(Order Details)作一個反向條件嵌套。

以下是兩種查詢方法在SQL語句和SQL Artisa組件下的實現。

(代碼只是用于表達SQL Artisan組件的功能,對于SQL語句本身存在的其他問題不作討論)

SQL方法一:

       SELECT Sum(UnitPRice*Quantity*(1-Discount)) FROM Employees INNER JOIN Orders ON Employees.EmployeeID=Orders.EmployeeID INNER JOIN [Order Details] ON Orders.OrderID=[Order Details].OrderID  where ( ( Employees.EmployeeID = 3 And Orders.OrderDate >= '1997-7-1' )  And Orders.OrderDate <= '1997-8-1')

 

SQL Artisan方法一:

       query = session.CreateQuery(Employees.TBL.INNER(Orders.TBL,Orders._EmployeeID)&

                       Orders.TBL.INNER(OrderDetails.TBL,Orders._OrderID));

query.Selects= new FieldAdapter[]{SqlMath.Sum(OrderDetails._UnitPrice*OrderDetails._Quantity*(1-OrderDetails._Discount))};

     query.Expreesion = Employees._EmployeeID.At(Employees.TBL) ==3 &

             Orders._OrderDate.At(Orders.TBL) >= DateTime.Parse("1997-7-1")&

            Orders._OrderDate.At(Orders.TBL) <= DateTime.Parse("1997-8-1");

     ds = query.ExecuteDataSet();

SQL方法二:

       SELECT Sum(UnitPrice*Quantity*(1-Discount)) FROM [Order Details]  where OrderID in (select OrderID from Orders where ( ( ( OrderDate >= '1997-7-1'And OrderDate < '1997-8-1' )  And EmployeeID in (select EmployeeID from Employees where ( EmployeeID = 3 )) ) ))

 

SQL Artisan方法二:

IQuery query = session.CreateQuery(OrderDetails.TBL);

query.Selects= new FieldAdapter[]{SqlMath.Sum(OrderDetails._UnitPrice*OrderDetails._Quantity*(1-OrderDetails._Discount))};

     query.Expreesion = OrderDetails._OrderID.In(Orders.TBL,Orders._OrderID,

              Orders._OrderDate >= DateTime.Parse("1997-7-1") &

              Orders._OrderDate < DateTime.Parse("1997-8-1") &

     Orders._EmployeeID.In(Employees.TBL,Employees._EmployeeID,Employees._EmployeeID ==3));

     System.Data.DataSet ds = query.ExecuteDataSet();

 

從以上代碼可以看到SQL Artisan組件通過字段對象的In方法方便靈活地把多層條件嵌套起來,在編寫這么煩瑣的查詢條件時用字符串拼揍SQL語句對開發人員來說并不是什么惡夢,但在人手檢測其合法性上也是個非常頭痛的問題;何況很多時候要面對更復雜的查詢條件。

SQL Artisan給你所帶來的是完全對象化的條件編寫方式并提供開發環境的編譯檢測,大大提高了條件的編寫效率和質量。

其實SQL兩個方法的的SQL語句都是通過運行SQL Artisan方法過程中截取的.

 相應例子下載


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 凌源市| 灵武市| 汤原县| 九寨沟县| 蒲江县| 建始县| 晋宁县| 尖扎县| 定安县| 壶关县| 牟定县| 哈尔滨市| 华蓥市| 应用必备| 淮阳县| 绥宁县| 秭归县| 自贡市| 新兴县| 阳城县| 定结县| 万盛区| 湘潭县| 梁山县| 钟山县| 栾城县| 徐闻县| 东乡县| 大荔县| 方正县| 南充市| 彭水| 嵊州市| 梧州市| 屯昌县| 盘锦市| 广灵县| 东港市| 会昌县| 威信县| 禹城市|