com.apache.dc.query.Query所属包名apache-common-sid.jar

首先这个类是基于HQL的,好多方法里面要传String clzz, 刚开始我真不知道这个参数传什么,后来看别人的代码才知道

要填 Entity.class.getName() 当然了这是一个字符串,你当然也可以直接拼好,"cn.angelshelter.utils.User"

并不推荐用手动拼好的字符串,因为一旦你拼错了,它方法里面的检查机制就会发现找不到这个类,然后

就报空指针错误,这个也只有在运行时才暴露出来,隐蔽性很强,如果用 User.class.getName()就没有这个问题了。

queryMapWithoutSelect(Map<String, Object> map, String clzz) 根据Map里面的条件参数去查找数据。

组装成的HQL例子: from cn.angelshelter.utils.User t where 1=1 and t.userid= 'value'

(它这里设计得不错,如果Map里有存在的字段,它会自动过滤掉,这样就不容易出错,但不过好像

不太容易排查问题了,你可能拼错一个字段,最后它没生效,它也没报错,你以为它生效了,因为程序员的

直觉,只是不报错,我的程序就是ok,这个潜在的bug发现任务可能就交给测试员了,呵呵,如果测试员也马虎的

话,那这个bug就一直隐藏在那里了,随时都有可能爆发的哦,好危险的感觉)

sort(String fieldName, boolean isAsc) 排序
这里没对非法字段名过滤。

select()  只是在HQL里面append了一个select

Query.update(String clzz) 更新
组装成的HQL例子: update cn.angelshelter.utils.User

Query.clzz(String className) 产生一个表的查询语句
组装成的HQL例子: from cn.angelshelter.utils.User t

set(Map<String, String> param) 在现有的HQL的基础上append "set xxx=xxx , xxx=xxx"

组装成的HQL例子:set userid3='value' , userid='value'

queryMapFullJoinWher(Map<String, Object> map, String clzz) 也是条件查询,不过它用了一个Map

组装成的HQL例子: select new map( t.name as name , t.pwd as pwd , t.userid as userid ) from cn.angelshelter.utils.User t where 1=1 and t.pwd= 'value' and t.userid= 'value'

queryMapFullJoinWhereForSql(Map<String, String> fields, Map<String, Object> map, String clzz) 第一个参数,控制字段,第一个参数,控制条件

组装成的HQL例子:select t.userid as userid from t_CdnSwitchover t where 1=1 and t.userid= 'value'

fullJoinWhere(String clzz) 全查询

组装成的HQL例子:select new map( t.name as name , t.pwd as pwd , t.userid as userid ) from cn.angelshelter.utils.User t where 1=1

fullJoinWhereForSql(Map<String, String> fieldNames, String clzz) 第一个参数控制字段

select t.pwd as pwd , t.userid as userid from t_CdnSwitchover t where 1=1

where()

组装成的HQL例子:where 1=1

.leftBracket()
HQL末尾追加 (

rightBracket();

HQL末尾追加 )

and();
HQL末尾追加 and

count()
注意,它本身不改变HQL,而是以返回字符串的形式select count(*) ...

toHql()
返回HQL

or()

HQL末尾追加 or

eq(String fieldName, String value)  等于
组装成的HQL例子: t.ff= 'dfdf'

eqNumber(String fieldName, String value) 名不符实
组装成的HQL例子:t.dfd= '55'

eqNumber(String fieldName, String value) 没啥用,还不如直接用eq
组装成的HQL例子:t.dfd= 'dfd'

period(Period period)  设置时间区间

Period period = new Period();
period.setBegin(new Date());
period.setEnd(new Date());
period.setKeyField("userid");
query.period(period);

组装成的HQL例子:t.userid>='2016-03-05 22:38:06' and  t.userid<='2016-03-05 22:38:07'

periodForSql(Period period) 感觉没有什么不同

ne(String fieldName, String value) 不等于

组装成的HQL例子:t.dd<> 'dfd'

lt(String fieldName, String value) 小于
组装成的HQL例子:t.fieldName< 'value'

le(String fieldName, String value) 小于或等于
组装成的HQL例子:t.fieldName<= 'value'

gt(String fieldName, String value) 小于
组装成的HQL例子:t.fieldName> 'value'

ge(String fieldName, String value) 大于或等于

组装成的HQL例子:t.fieldName>= 'value'

bw(String fieldName, String value) 包含

组装成的HQL例子:t.fieldName like '%value%'

in(String fieldName, String value) 在里面
组装成的HQL例子:t.fieldName in ( 'dfd,ll' )

in(String fieldName, Integer... values) 在里面
组装成的HQL例子:t.fieldName in (12,56 )

in(String fieldName, Long... values) 在里面

in(String fieldName, String... values)  在里面

ni(String fieldName, String value) 不在里面
组装成的HQL例子:t.fieldName not in ( 'd' )

isnull(String fieldName) 为空
组装成的HQL例子:t.fieldName is null

isnotnull(String fieldName) 不为空
组装成的HQL例子:t.fieldName is not null

orderBy() HQL append " order by "

forupdate() HQL append " for update"

limitOne()
组装成的HQL例子:limit 0,1

limit(int m, int n)
组装成的HQL例子:limit m,n

queryMap(Map<String, String> map, String clzz) 不知道是不是一个bug
select from cn.angelshelter.utils.User t where 1=1 and t.pwde= 'null' and t.userid= 'null' value部分都显示为Null

queryForMap(Map<String, Object> map, String clzz) 增加参询条件
组装成的HQL例子:and t.userid= 'value'

deleteMapWithoutSelect(Map<String, Object> map, String clzz) 条件删除
delete from cn.angelshelter.utils.User t where 1=1 and t.userid= 'value'

queryMapWithoutSelect(Map<String, Object> map, String clzz)

from cn.angelshelter.utils.User t where 1=1 and t.userid= 'value'

搞到最后,发现没有手动设置HQL的方法。。。

最后说一个最复杂的方法,不过感觉也没什么实用的价值。

Query.queryRelateClass(String clzz, String subClass)  联表查询

@WsTitle(isRelate=true, rlClass="cn.angelshelter.utils.Address", rlFieldCode="id")
private int ck;

你需要在User里面配好参数,包括这个字段是否关联,关联的类,以及关联类的哪个属性。

select a from cn.angelshelter.utils.Address a ,cn.angelshelter.utils.User t where t.ck = a.id

com.apache.dc.query.Query所属包名apache-common-sid.jar的更多相关文章

  1. 23.包、修饰符、jar

    下面都是在记事本里面写代码 1. 包的定义格式: package 包名(全小写)  例如: package a; 注意: 1)package语句必须位于java文件的第一个语句 2.编译运行 注意: ...

  2. 监听Google Player下载并获取包名等信息

    一.解决思路 通过监听ContentObserver监听下载路径content://downloads 二.具体步骤 1 设置监听器 context.getContentResolver() .reg ...

  3. 烂泥:Linux源码包制作RPM包之Apache

    本文由秀依林枫提供友情赞助,首发于烂泥行天下 公司服务器比较多,需要把apache源码包制作成rpm包,然后放到公司内网yum源上进行下载安装.apache的rpm包安装方式比源码安装方式比较快,这能 ...

  4. 如何用Android Studio打多包名APK

    问题:项目中不同的分发渠道可能需要打包多种APK(同样的代码),包名可能是不一样的,如果一个一个修改包名重新编apk是很麻烦,可以参考下列步骤在Android Studio上操纵Gradle来打包不同 ...

  5. 如何判断是否为同一个App,Ionic3如何修改包名

    如何判断是否同一个App 使用Ionic3创建了两个项目demo1.demo2,然后使用同一个JDK,生成了两个不同的keystore证书. 结果在手机端安装的时候,先安装demo1,没有任何替换的提 ...

  6. Caused by: org.springframework.beans.factory.BeanCreationException: Could not autowire field: private com.******.seashell.bpc.query.query.service.FscBankPayCodeQueryService

    2019-03-19 16:22:14,945 WARN [main] (org.springframework.context.support.AbstractApplicationContext. ...

  7. war包部署到服务器后,如何直接访问,而不需要在地址后面加war包名

    正常情况下,但我们把war部署到服务器上,访问地址是:服务器ID:端口/war包名 但是如果个人建站显然不适合以此方式. 方式一:修改服务器Tomcat的server.xml配置 注意:你的报名如果是 ...

  8. jar包中存在包名和类名都相同的情况

    情况: 在maven中引入两个包都有项目的包名和类名,只是jar包的名字不同.两个包的一部分在代码中的不同地方都需要用到. 网上找的大部分都是: 只有改变编译器优先选择的jar顺序(这个顺序是可以改变 ...

  9. MAC OS X El CAPITAN 搭建SPRING MVC (1)- 目录、包名、创建web.xml

    一. 下载STS(Spring Tool Suite) 官方地址:http://spring.io/tools/sts 下载spring tool suite for mac 最新版本.这个IDE是很 ...

随机推荐

  1. 报错:HTTP Status 404 - There is no Action mapped for namespace [/] and action name [product-save] associated with context path [/20161101-struts2-2].

    运行:index.jsp---->input.jsp----->details.jsp,但是在input.jsp到details.jsp的时候报错误. 异常如下: 严重: Could no ...

  2. python xlwt,xlutils 在excel里面如何插入一行数据

    就是把插入行之后值重新输出来. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 import xl ...

  3. spring java 获取webapp下文件路径

    spring java 获取webapp下文件路径 @RequestMapping("/act/worldcup_schedule_time/imgdownload") @Resp ...

  4. Java 程序优化:字符串操作、基本运算方法等优化策略(二)

    五.数据定义.运算逻辑优化 多使用局部变量 调用方法时传递的参数以及在调用中创建的临时变量都保存在栈 (Stack) 里面,读写速度较快. 其他变量,如静态变量.等,都在堆实例变量 (heap) 中创 ...

  5. Xamarin.Forms介绍

    On May 28, 2014, Xamarin introduced Xamarin.Forms, which allows you to write user-interface code tha ...

  6. 因开启SELinux导致httpd报403

    各项权限都检查过了,SELinux允许的端口也找过了.同目录下的其他文件夹是正常的,这个文件夹就抱403. 临时关闭selinux后正常.估计是没有配置运行上下文. chcon -R -t httpd ...

  7. restfull api

    REST 表示状态传输.这是一个体系结构样式,可用于设计网络服务,可以被各种客户端消耗.核心思想是,不使用如CORBA,RPC或SOAP复杂的机制在机器之间进行连接,简单的 HTTP 用于使它们之间调 ...

  8. 在linux下获取帮助

    1.使用man手册页 man是一种显示Unix/Linux在线手册的命令.可以用来查看命令.函数或文件的帮助手册,另外它还可以显示一些gzip压缩格式的文件. 读者在遇到不懂的命令时,可以用man查看 ...

  9. 不让Win7休眠的设置

    1:原因 目前有一个项目是采用微服务的架构搭建的,其中一个微服务的数据库是在一位同事的电脑上(Win7系统),一旦这台电脑休眠,对应的数据库服务就访问不了,所以,需要保持此台电脑永不休眠. 2:傻瓜式 ...

  10. 基于boa服务器的web控制mini2440的GPIO口

    win7 系统  虚拟机:ubuntu12.04 开发板:mini2440 上一篇已经详细的讲解了如何配置boa服务器,在这里我们就要利用boa服务器带来的便利,利用web控制开发板上的GIPO口,这 ...