复杂的SQL条件总结.pdfVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
复杂的 SQL 条件 概述 什么是 Nutz.Dao 中的复杂 SQL 条件 对于 Nutz.Dao 来说, 它本质上就是将你的 Java 对象转化成 SQL ,然后 交给 JDBC 去执行。 而 SQL 中,当执行数据删除和查询操作时,最常用的就是 WHERE 关键 字。 WHERE 关键字后面的就是所谓的复杂查询条件 Nutz.Dao 将如何如何使用这个条件 Dao 接口的 clear 方法和 query 方法的第二个参数,就是为了生成 WHERE 后面那段字符串设计的 这个参数是一个 org.nutz.dao.Condition 接口的实现类 通过该接口的 toString(org.nutz.dao.entity.Entity) 方法, Nutz.Dao 将获 得 WHERE 后面那段字符串 当然也包括 ORDER BY Condition 接口 这个接口只有一个方法 toString(Entity entity) o 这个方法带一个参数 org.nutz.dao.entity.Entity o 通过这个参数, 实现者可以获得当前需要操作的实体的配置 信息 o 当然,如果你不需要的话,你可以不理睬这个参数 Nutz.Dao 会将 toString(Entity entity) 的返回直接拼接到 SQL 的 WHERE 关键字后面 o 如果你返回的字符串以 WHERE 或者 ORDER BY 开头, 它会直接使用,否则会补上一个 WHERE 关键字 o 这个判断会忽略前后空白以及大小写 Nutz 给你的快速实现 如果你的数据库字段被假设不会发生变化,用直接硬编码是个很好的选择 如果在开发期, 你的数据库字段变化非常频繁, 用 Cnd 工具类则是更好的 选择 直接硬编码 最简单直接的方法就是直接输出 WHERE 关键字后面的 SQL 代码了。 比 如查询一个 Person 对象 ListPerson crowd = dao.query(Person.class, Cnd.wrap(name LIKE J% AND age20), null); 这句话,就会将所有名称以 J 开头,并且年龄超过 20 岁的人全部查询出 来。参看 Nutz.Dao 入门 针对 Person 对象的描述,实际上,上面那句话 执行的 SQL 代码为: SELECT * FROM t_person WHERE name LIKE J% AND age20; 当然你要是写 Cnd.wrap(name LIKE J% AND age20 ORDER BY name ASC); 就会按照 name 字段排序。 一个友好一些的工具类 -- Cnd 有些情况,数据库中的字段同 Java 对象中的字段并不同名,所以就需要 给 Java 字段上的数据库字段注解加上参数 @Column( 数据库字段名 ) 如果你通过 Cnd.wrap() 硬编码某个字段,那么当这个字段数据库字段名 发生改变时,你就需要改动很多。因此你希望仅仅将对于数据库的变动限 制在 J

文档评论(0)

蔡老二学教育 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档