SmartPersistenceLayer 2.0 之Query高级查询篇

总述

在看了前面的功能后,大家都会考虑到多表之间的查询怎么办.在这里,我想先讲一下查询在应用系统中的复杂性/重要性/可行性.

重要性:查询统计是系统维护的一个目标之一,是系统的一个必不可少的部分,因此,在绝大部分的系统中,都会有查询统计。

复杂性:查询是在系统开发中一个最复杂的部分,谁都无法预料查询统计的复杂性,哪怕是在一个小型系统中,因此,在SPL中也是无法实现这么多的查询统计,为了兼容,SPL也努力实现了它所能做的,就是”联合查询”功能,将通过Query类来完成.

可行性:要能快速,有效的应付复杂多变的查询与统计,在我看来,用视图进行处理是一个最有效的方式.一是视图的高速:数据库的视图查询要比执行SQL来的快多,因为数据库会为视图进行缓存.二是开发快速性:写SQL语句需要很多时间,而且查询汇总的语句都是相当复杂的,所以也容易出错,而视图会把问题变的非常简单,开发速度大大提高.三是维护性:由于查询的复杂性,变动频繁将是最明显的特征,所以SQL语句的应变能力没有视图来得好.

因此,我的建议是对于一些查询与统计,我们应尽可能的采用视图来做.简单的查询当然可以使用SQL.现在来介绍SPL中的Query联合查询.

联合查询

例子:A表的ID与B表的AID有关联,我们要关联A/B表,选择A表的NAME和B表的COMPANY值.

Query q1=new Query(typeof(A));           //建一个A表的Query

q1. AddAttribute(A.NAME);                    //添加一个要选择的字段

Condition c=q1. GetQueryCondition();         //A表产生一个查询

c.AddEqualTo(“Name”,”tintown”);              //给A添加条件,请参考Condition

q1.OrderBy(“Name”);                     //添加一个排序,请参考RetrieveCriteria

Query q2=new Query(typeof(B));              //建一个B表的Query

q2.AddAttribute(B.COMPANY,”公司名”);      //添加另一个选择的字段,以别名输出

q1. AddJoinQuery(A.ID,q2,B.AID);            //把q1与q2关联起来

DataTable dt=q1. Execute();                 //执行查询

步骤分析:

1. Query的创建与Criteira差不多一样的,要指定一个实体类型typeof(A)

2. 由于是多表查询,所以要求设定选择哪些字段,目前SPL中有三种方式:

1.      AddAttribute(字段名):这是直接以字段名为输出名

2.      AddAttribute(字段名,别名):这是可以把字段名以别名的方式输出

3.      AddAttribute(AttributeType.All):这是指以*号的方式全部显示

3. 使用Execute()执行后返回DataTable类型,可以直接绑定用。

在使用这种输出字段时,要注意不能重名输出,尤其是在使用了*号后,因为会正在一些不可预测的字段重名,所以,建议尽可能使用别名

通过以上的方式就可以实现大多数表之间的联合查询.以上有个局限性:表写表之间的关系都是inner join的.也就是无法实现左连接效果,对于这种查询,我还是建议使用视图.

其他的Condition与OrderBy都与RetrieveCriteria类似,不再赘述。

统计查询

对于汇总查询本身也是非常复杂的,SPL也只能实现简单的汇总,对于复杂性的汇总还是建议使用视图或是SQL进行.

Query q1=new Query(typeof(A));

q1.AddAttribute(A.NAME):                 //显示NAME

q1.SelectMax(A.PRICE,”MAXPRICE”);             //统计最高价格,别名MAXPRICE

q1.SelectSum(A.PRICE,”ALLPRICE”);              //统计价格总和,别名ALLPRICE

q1.SelectAvg(A.PRICE,”AVGPRICE”);             //统计平均价格,别名AVGPRICE

q1.SelectCount(A.NAME,”COUNT”);               //统计条数,别名COUNT

q1.GroupBy(A.NAME);                           //接NAME进行分组

q1. Execute();                                 //执行

使用SelectMax,SelectSum,SelectAvg,SelectCount进行简单的汇总,上面的例子是显示多汇总值的情况,所以是采用Execute()方法.

SPL还提供了单返回的方式:

Query q=newQuery(typeof(A);

q.SelectCount(A.ID);

intre=q. ExecuteScalar();

这可以返回条数,其实在SPL中就是获取第一条记录的第一列值。

SQL语句执行

为了扩展兼容性,还是要提供最基本的SQL语句执行接口,对于一些复杂的语句,可以使用SQL语句的执行来解决,实现的方式也是非常简单:

string sqlString=”select name from A whereprice>1000”;

Query. ProcessSql(sqlString,”dbName”);

这里的dbName 是指语句针对哪个数据源进行操作,当然要注意的,通过SQL执行返回的字段名,是数据库的实际的字段名了,而不是实体的属性名了。

DISTINCT功能

在SPL中可以使用IsDistinct属性来使用DISTINCT功能,这将最终生成”Select distinct…”的语句。

存储过程

SPL中也同样支持存储过程,我们也可以通过Query的静态类完成:

IDataParameterpara=Query.GetParameter("northwind"); //创建一个参数

para.ParameterName="@name1";  //定义参数名

para.Value="f";              //定义参数值

IDataParameter[] paras=new IDataParameter[1];  //定义参数数组

paras[0]=para;         //给数组赋个参数

DataTabledt=Query.RunProcedure("test",paras,"northwind"); //执行存储过程

[置顶] SPL讲解(7)--Query高级篇的更多相关文章

  1. [置顶] SPL讲解(4)--Criteria操作篇

    概念 以前一篇文章中,描述了实体Entity的操作,很明显,仅仅实体的操作是远远不够的.如:我们经常会根据查询条件从数据库中获取记录集并绑定到DataGrid上,会根据条件进行批量的Update和De ...

  2. [置顶] SPL讲解(6)--Condition篇

    SmartPersistenceLayer 2.0 之 Condition篇 原理        强大的Condition功能是SPL的一个特性,可以使用Condition完成绝大部分的条件定义,使用 ...

  3. [置顶] mmog游戏开发之业务篇

    这周不是很忙,因为我们的游戏开发了近一年,由于公司的业务调整,在游戏开第二服的时候,老板果断的把项目停到了. 感觉超级的不爽啊.因为这个游戏项目像我的孩子一样和我一样成长,里边的大概的业务逻辑都是偶实 ...

  4. SpringBootTest单元测试实战、SpringBoot测试进阶高级篇之MockMvc讲解

    1.@SpringBootTest单元测试实战 简介:讲解SpringBoot的单元测试 1.引入相关依赖 <!--springboot程序测试依赖,如果是自动创建项目默认添加--> &l ...

  5. [知了堂学习笔记]_css3特效第二篇--行走的线条&&置顶导航栏

    一.行走的线条. 效果图(加载可能会慢一点儿,请稍等...): html代码: <div class="movingLines"> <img src=" ...

  6. css3特效第二篇--行走的线条&&置顶导航栏

    一.行走的线条. 效果图(加载可能会慢一点儿,请稍等...): html代码: <div class="movingLines"> <img src=" ...

  7. PHP笔记(PHP高级篇)

    高级篇中将涉及数据库的使用以及Cookie和Session会话,提高PHP的开发效率和运行效率 PHP程序员需要掌握的MySQL操作 为项目设计表 使用SQL语句 MySQL的目录结构 data目录中 ...

  8. 数据库MySQL学习笔记高级篇

    数据库MySQL学习笔记高级篇 写在前面 学习链接:数据库 MySQL 视频教程全集 1. mysql的架构介绍 mysql简介 概述 高级Mysql 完整的mysql优化需要很深的功底,大公司甚至有 ...

  9. Vue2和Vue3技术整理3 - 高级篇

    3.高级篇 前言 基础篇链接:https://www.cnblogs.com/xiegongzi/p/15782921.html 组件化开发篇链接:https://www.cnblogs.com/xi ...

随机推荐

  1. Red Hat Enterprise Linux 7的新功能

     简介红帽最新版本的旗舰平台交付显著增强的可用性. 性能和可靠性. 丰富的新功能为架构. 系统管理员和开发人员提供所需的资源以更高效地进行创新和管理.架构师: 红帽® 企业 Linux® 7 适合 ...

  2. cf448D Multiplication Table

    D. Multiplication Table time limit per test 1 second memory limit per test 256 megabytes input stand ...

  3. Asp.net MVC 3 防止 Cross-Site Request Forgery (CSRF)原理及扩展 安全 注入

    原理:http://blog.csdn.net/cpytiger/article/details/8781457 原文地址:http://www.cnblogs.com/wintersun/archi ...

  4. 虚函数virtual

    简单地说,那些被virtual关键字修饰的成员函数,就是虚函数.虚函数的作用,用专业术语来解释就是实现多态性(Polymorphism),多态性是将接口与实现进行分离:用形象的语言来解释就是实现以共同 ...

  5. 04747_Java语言程序设计(一)_第4章_数组和字符串

    面试题 字符串连接 public class Aserver { public static void main(String args[]) { // 字符串数据和其他数据+,结果是字符串类型 // ...

  6. Linux 块设备驱动 (一)

    1.块设备的I/O操作特点 字符设备与块设备的区别: 块设备只能以块为单位接受输入和返回输出,而字符设备则以字符为单位. 块设备对于I/O请求有对应的缓冲区,因此它们可以选择以什么顺序进行响应,字符设 ...

  7. Dynamics CRM2013 missing prvReadComplexControl privilege

    左右ComplexControl 权限设置,SDK例如,在以下的说明,仅供内部使用的实体,但是你可以没有找到这个叫配置安全角色ComplexControl的东西的. 在msdn上面查下就会发现这么一段 ...

  8. codevs1009

    题目地址:http://codevs.cn/problem/1009/ 分析: [TAG]FLOYD,乘法原理,高精度 [构思] 求可变换数的个数,那么就是组合数学的内容,四个原理的应用: 假如能知道 ...

  9. last与lastlog命令

    lastlog 列出所有用户最后登录的时间和登录终端的地址,如果此用户从来没有登录,则显示:**Never logged in**last 列出用户所有的登录时间和登录终端的地址

  10. (转)实例详解CSS中position的fixed属性使用

    关于fixed属性,在什么情况下需要用,怎么用,首先,我们应该先了解下fixed属性的说明:fixed总是以body为定位时的对象,总是根据浏览器的窗口来进行元素的定位,通过"left&qu ...