QuickDAOJava ORM 框架
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实现)
<dependency> <groupId>commons-dbcp</groupId> <artifactId>commons-dbcp</artifactId> <version>1.4</version> </dependency>
2.1 使用maven
<dependency>
<groupId>cn.schoolwow</groupId>
<artifactId>QuickDAO</artifactId>
<version>2.4</version>
</dependency>
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> 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<User> userList = dao.query(User.class)
.addNotEmptyQuery("username")
.getList();
关于复杂查询详细信息请点此查看
3.3 外键查询
List<User> userList = dao.query(User.class)
.join(UserSetting.class,"id","userId")
.addNotEmptyQuery("setting")
.done()
.getList();
关于外键查询详细信息请点此查看
3.3 分页排序查询
List<User> 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项目!
评论