设为首页 收藏本站
查看: 1055|回复: 0

[软件发布] dexcoder

[复制链接]

尚未签到

发表于 2016-5-25 08:31:30 | 显示全部楼层 |阅读模式
欢迎加入运维网交流群:263444886   DSC0000.png
  该通用dal是在开发过程中,对于简单封装的通用dao或数据访问层使用深感痛苦与不便,由此进行了整合和改进发展而来。
  如果你不喜欢用Hibernate、Mybaits这类ORM框架,喜欢Spring JdbcTemplate或DbUtils,那么可以试试这个封装的通用dal,这可能是目前封装的最方便易用的通用dal层了。
dexcoder-dal 2.3.0 更新说明:

  •   实体类表名及属性名映射增加注解支持
  •   增加更多的执行自定义sql方法
  •   因为sql权限问题去掉使用TRUNCATE的deleteAll方法
  •   修正使用注解时注解的属性名不遵循规范时get方法主键错误问题
  •   修正水平拆分数据分表不根据主键拆分时update无法获取表名的问题
  •   修改NameHandler类名为MappingHandler
  配置动态数据源请看这里:在dexcoder-dal中使用动态数据源并设置读写分离
  数据水平分表请看这里:在dexcoder-dal中实现分表数据水平拆分
dexcoder-dal的一些特性:

  •   一个dao即可以搞定所有的实体类,不必再一个个建立跟实体对应的继承于类似BaseDao这类“通用dao”了。
  •   各类方法参数除了Entity外,支持更强大的Criteria方式。
  •   sql的where条件支持一些复杂的条件,如=、!=、or、in、not in甚至是执行函数。
  •   允许在查询时指定使用哪个字段进行排序,可以指定多个进行组合升降序自由排序。
  •   支持在查询时指定返回字段的白名单和黑名单,可以指定只返回某些字段或不返回某些字段。
  •   select查询时支持函数,count()、max()、to_char()、甚至是distinct,理论上都可以支持。
  •   方便强大的分页功能,无须额外操作,二三行代码搞定分页,自动判断数据库,无须指定。
  •   可以使用{}和[]完成一些特殊的操作,{}中的代码将原生执行,[]中的代码会进行命名转换,一般fieldName转columnName。
  •   支持执行自定义sql。
  •   支持使用类似mybatis的方式执行自定义sql。
  •   支持读写分离和动态数据源。
  •   对于数据分表水平拆分支持友好。
  使用dexcoder-dal,maven坐标
  
    com.dexcoder
  
    dexcoder-dal-spring
  
    ${version}
  

几个示例
  select
//白名单、in、括号、or、asc、desc  
//最终sql:SELECT LOGIN_NAME FROM USER WHERE USER_TYPE in (?,?) and ( LOGIN_NAME =  ? or EMAIL =  ? ) and PASSWORD =  ? and  (USER_AGE = ? OR USER_AGE = ? OR USER_AGE = ?)  ORDER BY USER_ID ASC,USER_AGE DESC
  
Criteria criteria = Criteria.select(User.class).include("loginName")
  
        .where("userType","in", new Object[] { "1", "2" }).begin().and("loginName", new Object[] { "javaer" })
  
        .or("email", new Object[] { "javaer@live.com" }).end().and("password", new Object[] { "123456" })
  
        .and("userAge", new Object[] { 18, 19, 20 }).asc("userId").desc("userAge");
  
List users = jdbcDao.queryList(criteria);
  update
user.setPassword("abcdef");  
//方式一 为null的属性值将被忽略
  
jdbcDao.update(user);
  

  
//方式二 为null的属性值将更新到数据库
  
jdbcDao.update(user,false);
  

  
//方式三 criteria 这里的email设为null也将被更新
  
Criteria criteria = Criteria.update(User.class).set("password", "update222").set("email",null)
  
    .where("userId", new Object[] { 56L, 57L, 58L });
  
jdbcDao.update(criteria);
  分页
//进行分页,只需要增加这行,查询方式上没有任何区别  
PageControl.performPage(user);
  
jdbcDao.queryList(user);
  
//分页后数据由PageControl中获取
  
Pager pager = PageControl.getPager();
  
//列表
  
List users = pager.getList(User.class);
  
//总记录数
  
int itemsTotal = pager.getItemsTotal();
  执行函数
//max()  
Criteria criteria = Criteria.select(User.class).addSelectFunc("max([userId])");
  
Long userId = jdbcDao.queryForObject(criteria);
  

  
//count()
  
Criteria criteria = Criteria.select(User.class).addSelectFunc("count(*)");
  
Long count = jdbcDao.queryForObject(criteria);
  

  
//distinct
  
Criteria criteria = Criteria.select(User.class).addSelectFunc("distinct [loginName]");
  
List mapList = jdbcDao.queryForList(criteria);
  

  
//where中
  
Criteria criteria = Criteria.select(User.class).where("[gmtCreate]", ">",
  
    new Object[] { "str_to_date('2015-10-1','%Y-%m-%d')" });
  
List userList = jdbcDao.queryList(criteria);
  更多详细信息请查看:http://git.oschina.net/selfly/dexcoder-assistant 

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-221415-1-1.html 上篇帖子: Linux 内核 4.4 LTS 详细说明,虚拟机可玩 OpenGL 下篇帖子: Beetl 2.2.9 发布,Java 模板引擎
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表