java mysql orm框架_QuickDAO

软件简介

QuickDAO

QuickDAO 是一款简单,易用,轻量级的java ORM框架.目前支持 Mysql, SQlite 以及 H2 数据库.

SpringBoot环境下由于类加载器问题请慎用,可能会导致未知问题出现!

QuickDAO目前没有在高并发环境下实践过,因此对于高并发项目请慎用.本项目适合于中小项目使用,提供封装良好的API与数据库进行交互,减少样板代码,尽可能提高开发效率!

目前QuickDAO使用Logback日志框架,DEBUG级别下会输入执行的SQL语句!

快速入门

1 建立实体类

//用户类

public class User {

private long id;

private String username;

private String password;

//用户设置表

public class UserSetting {

private long id;

private long userId;

private String setting;

private User user;

//用户关注表

public class UserFollow {

private long id;

private long userId;

private long followerId;

private User user;

private User followUser;

2 导入QuickDAO

QuickDAO基于JDBC,为提高效率,默认只支持数据库连接池.

导入commons-dbcp(或者其他的DataSource实现) commons-dbcpcommons-dbcp1.4

2.1 使用maven

cn.schoolwow

QuickDAO

2.4

3 使用QuickDAO

QuickDAO支持自动建表,自动新增字段功能.当您在Java代码中配置好QuickDAO后无需再对数据库做任何操作.

BasicDataSource mysqlDataSource = new BasicDataSource();

mysqlDataSource.setDriverClassName("com.mysql.jdbc.Driver");

mysqlDataSource.setUrl("jdbc:mysql://127.0.0.1:3306/quickdao");

mysqlDataSource.setUsername("root");

mysqlDataSource.setPassword("123456");

//指定���体所在包名

cn.schoolwow.quickdao.dao.DAO dao = QuickDAO.newInstance()

.dataSource(mysqlDataSource)

.packageName("cn.schoolwow.quickdao.entity")

.build();

//之后所有的操作使用dao对象完成

3.1 简单查询与更新操作

//根据id查询

User user = dao.fetch(User.class,1);

//根据属性查询

User user = dao.fetch(User.class,"username","quickdao");

List user = dao.fetchList(User.class,"password","123456");

//保存用户

dao.save(user);

dao.save(userList);

//删除用户

dao.delete(User.class,1);

dao.delete(User.class,"username","quickdao");

3.2 复杂查询

List userList = dao.query(User.class)

.addNotEmptyQuery("username")

.getList();

关于复杂查询详细信息请点此查看

3.3 外键查询

List userList = dao.query(User.class)

.join(UserSetting.class,"id","userId")

.addNotEmptyQuery("setting")

.done()

.getList();

关于外键查询详细信息请点此查看

3.3 分页排序查询

List userList = dao.query(User.class)

.pageNumber(1,10)

.orderByDesc("id")

.getList();

关于分页排序详细信息请点此查看

3.4 建表删表

//删除User表

dao.drop(User.class);

//建立User表

dao.create(User.class);

详细手册

实体注解 QuickDAO有自动建表功能,用户可使用注解为实体类信息添加相关字段信息.同时QuickDAO能够自动匹配实体类和数据库表,自动添加新增的实体类字段信息.

配置信息 QuickDAO可配置是否自动新建表,是否建立外键约束,忽略表和包等等.

事务功能 QuickDAO基于JDBC封装了简单的事务功能.若需使用事务,请查询此手册

请注意: 开启事务时只作用于调用方法的dao对象,若配置有多个dao对象,对其他dao对象无影响(也即其他dao对象不会跟着开启事务功能)!

QuickDAO本身提供了一套较完整的JUnit测试用例,可查看ConditionTest和DAOTest.

反馈

目前QuickDAO还不成熟,还在不断完善中.若有问题请提交Issue,作者将第一时间跟进并努力解决.同时欢迎热心认识提交PR,共同完善QuickDAO项目!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值