当前位置: 首页 > 工具软件 > QuickDAO > 使用案例 >

java mysql orm框架_QuickDAO

乐正焕
2023-12-01

软件简介

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项目!

 类似资料: