首 页 | 精品电影 | 音乐天堂 | 在线游戏 | Flash MTV | 三湘书屋 | 幽默笑话 | 三湘图库 | 美女写真 | IT知识库 | QQ贴图 | 加入书签

网页制作网络编程图形图象操作系统冲浪宝典软件教学网络安全认证考试通信技术电子商务业内动态书籍教程原码

最近更新 文章分类 多媒体类 精品软件

本站搜索:
您的位置:三湘时空 -> IT知识库 -> 文章分类 -> 数据库技巧 -> SQL Artisan多层查询条件嵌套功能
SQL Artisan多层查询条件嵌套功能


文章类别:数据库技巧 来源: 作者: 发表日期:2006-5-18 字体:[ ]

小游戏 | 在线影院 | 幽默笑话 | 源码下载 | Flash MTV | 音乐试听 | 书屋 | 美女写真

在实际开发过程中我们经常面对一些查询或统计子表信息,对于一层处理还是比较简单,如果二层、三层等或更多时这个时候编写出来的条件就比较复杂和容易出现编写错误的情况。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方法过程中截取的.

 相应例子下载

上一篇:File.Delete不能删除文件的问题 下一篇:photoshop 置换滤镜“重复边缘像素”和“折回”详解
本栏目热门文章
·Windows XP下安装SQL2000企业版 2005-10-4
·在SQL Server 2000里设置和使用数据库复制 2005-11-13
·SQL Server 数据库管理常用的SQL和T-SQL语句 2005-11-13
·SQL SERVER实用技巧 2005-11-3
·配置SQL Server 2000选项 2005-10-8
·如何使Microsoft SQL Server的日志文件不会增大? 2005-10-4
·SQL中通配符、转义符与"["号的使用(downmoon) 2005-11-3
·Sql Server下数据库链接的使用方法 2005-11-21
·使用SQL Server导入和索引 Microsoft Word 文 2005-10-4
·如何快速杀死占用过多资源(CPU,内存)的数据库进程 2005-11-13
新近更新文章
·Oracle:一条SQL实现将多行数据并为一行显示 2006-6-20
·Link Server的语法 2006-6-20
·通过查询分析器对比SQL语句的执行效率 2006-6-15
·问题“未于信任SQL Server连接相关联”的解决 2006-6-15
·数据库死锁导致网站站点访问不了之解决方案 2006-6-15
·在Access中模拟sql server存储过程翻页 2006-6-12
·SQL 存储过程&算法 2006-6-12
·SQL Server 2005 Express附加(Attach)的 2006-6-9
·在SQL Server 2005中实现表的行列转换 2006-6-6
·枚举SQL Server的实例 2006-6-6
首 页 | 软件发布 | 广告联系 | 下载帮助 | 意见反馈 | 网站地图
  CopyRight? 2002-2004 WWW.SXSKY.NET? All Rights Reserved
三湘时空 站长QQ:82675303 Email: