
MyBatis JPA Extra
MyBatis JPA Extra 对 MyBatis 扩展 JPA 功能
1.JPA 2.1 注释简化 CUID 操作 ;
2.Interceptor 实现数据库 SELECT 分页查询 ;
3. 链式 Query 查询条件构造器;
4. 提供 starter, 简化 SpringBoot 集成 ;
1、JPA 2.1 注释
1.1、注释
仅支持 6 个注释
- @Entity
- @Table
- @Column
- @Id
- @GeneratedValue
- @Transient
1.2、主键策略
| 序号 | 策略 | 支持 |
|---|---|---|
| 1 | AUTO | 4 种主键自动填充策略 snowflakeid (雪花 ID - 推荐 uuid(UUID uuid.hex (UUID 十六进制 serial (JPA Extra 序列 |
| 2 | SEQUENCE | 数据库序列生成,generator 值为数据库序列名 |
| 3 | IDENTITY | 数据库表自增主键 |
1.3、Java Bean 注释
@Entity @Table(name = "STUDENTS" public class Students extends JpaBaseEntity implements Serializable{ @Id @Column @GeneratedValue(strategy=GenerationType.AUTO,generator="snowflakeid" //@GeneratedValue(strategy=GenerationType.SEQUENCE,generator="SEQ_MYBATIS_STUD" //@GeneratedValue(strategy=GenerationType.IDENTITY private String id; @Column private String stdNo; @Column private String stdName; @Column private String stdGender; @Column private int stdAge; @Column private String stdMajor; @Column private String stdClass; @Column private byte[] images; public Students( {} //public get({}; public void set({}; }
2、基本操作
2.1、CURD
//新增数据
@Test
public void insert( throws Exception{
_logger.info("insert...";
Students student=new Students(;
student.setStdNo("10024";
student.setStdGender("M";
student.setStdName("司马昭";
student.setStdAge(20;
student.setStdMajor("政治";
student.setStdClass("4";
service.insert(student;
Thread.sleep(1000;
_logger.info("insert id " + student.getId(;
}
//查询数据实体并更新
@Test
public void update( throws Exception{
_logger.info("get...";
Students student=service.get("317d5eda-927c-4871-a916-472a8062df23";
System.out.println("Students "+student;
_logger.info("Students "+student;
_logger.info("update...";
student.setImages(null;
service.update(student;
_logger.info("updateed.";
student.setImages("ssss".getBytes(;
service.update(student;
_logger.info("updateed2.";
}
//根据实体查询并更新
@Test
public void merge( throws Exception{
_logger.info("merge...";
Students student=new Students(;
//student.setId("10024";
student.setStdNo("10024";
student.setStdGender("M";
student.setStdName("司马昭";
student.setStdAge(20;
student.setStdMajor("政治";
student.setStdClass("4";
service.merge(student;
Thread.sleep(1000;
_logger.info("merge id " + student.getId(;
}
//根据ID查询
@Test
public void get( throws Exception{
_logger.info("get...";
Students student=service.get("317d5eda-927c-4871-a916-472a8062df23";
System.out.println("Students "+student;
_logger.info("Students "+student;
}
//根据实体查询
@Test
public void query( throws Exception{
_logger.info("query...";
Students student=new Students(;
student.setStdGender("M";
List<Students> listStudents =service.query(student;
//...
}
//查询所有记录
@Test
public void findAll( throws Exception{
_logger.info("findAll...";
List<Students> listStudents =service.findAll(;
//...
}
//根据ID删除
@Test
public void remove( throws Exception{
_logger.info("remove...";
service.remove("921d3377-937a-4578-b1e2-92fb23b5e512";
}
//根据ID集合批量删除
@Test
public void batchDelete( throws Exception{
_logger.info("batchDelete...";
List<String> idList=new ArrayList<String>(;
idList.add("8584804d-b5ac-45d2-9f91-4dd8e7a090a7";
idList.add("ab7422e9-a91a-4840-9e59-9d911257c918";
idList.add("12b6ceb8-573b-4f01-ad85-cfb24cfa007c";
idList.add("dafd5ba4-d2e3-4656-bd42-178841e610fe";
service.deleteBatch(idList;
}
//根据ID批量逻辑删除
@Test
public void logicDelete( throws Exception{
_logger.info("logicDelete...";
List<String> idList=new ArrayList<String>(;
idList.add("8584804d-b5ac-45d2-9f91-4dd8e7a090a7";
idList.add("ab7422e9-a91a-4840-9e59-9d911257c918";
idList.add("12b6ceb8-573b-4f01-ad85-cfb24cfa007c";
idList.add("dafd5ba4-d2e3-4656-bd42-178841e610fe";
service.logicDelete(idList;
}
//根据ID批量删除
@Test
public void batchDeleteByIds( throws Exception{
_logger.info("batchDeleteByIds...";
service.deleteBatch("2";
service.deleteBatch("2,639178432667713536";
}
2.2、Find 查询和 Qruey 构造器
//springJDBC 的查询方式
@Test
public void find( throws Exception{
_logger.info("find by filter StdNo = '10024' or StdNo = '10004'";
List<Students> listStudents = service.find(" StdNo = ? or StdNo = ? ",
new Object[]{"10024","10004"},
new int[]{Types.VARCHAR,Types.INTEGER}
;
//...
}
//根据链式条件构造器查询
//WHERE (stdMajor = '政治' and STDAGE > 30 and stdMajor in ( '政治' , '化学' or ( stdname = '周瑜' or stdname = '吕蒙'
@Test
public void filterByQuery( throws Exception{
_logger.info("filterByQuery...";
List<Students> listStudents = service.query(
new Query(.eq("stdMajor", "政治".and(.gt("STDAGE", 30.and(.in("stdMajor", new Object[]{"政治","化学"}
.or(new Query(.eq("stdname", "周瑜".or(.eq("stdname", "吕蒙";
//...
}
2.3、分页查询并 count 数据量
//根据实体分页查询
@Test
public void queryPageResults( throws Exception{
_logger.info("queryPageResults...";
Students student=new Students(;
//student.setStdGender("M";
//student.setStdMajor(政治";
student.setPageSize(10;
//student.setPageNumber(2;
student.calculate(21;
JpaPageResults<Students> results = service.queryPageResults(student;
List<Students> rowsStudents = results.getRows(;
long records =results.getRecords(;//当前页记录数量
long totalPage =results.getTotalPage(;//总页数
long total =results.getTotal(;//总数据量
long page =results.getPage(;//当前页
//...
}
//mapper id分页查询
@Test
public void queryPageResultsByMapperId( throws Exception{
_logger.info("queryPageResults by mapperId...";
Students student=new Students(;
student.setStdGender("M";
//student.setStdMajor(政治";
student.setPageSize(10;
student.setPageNumber(2;
JpaPageResults<Students> results =
service.queryPageResults("queryPageResults1",student;
//...
}
3、版本更新
支持jdk 17
支持Spring 6
支持SpringBoot 3
底层代码优化