MyBatis JPA Extra 3.0 发布,支持 SpringBoot3
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 个注释
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
底层代码优化

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
智能制造一体化 v3.9.6 发布,工作流 更新
智能制造一体化管理系统[SpringBoot2 - 快速开发平台],适用于制造业、建筑业、汽车行业、互联网、教育、政府机关等机构的管理。包含文件在线操作、工作日志、多班次考勤、CRM、ERP 进销存、项目管理、EHR、拖拽式生成问卷、日程、笔记、工作计划、行政办公、薪资模块、动态表单、知识库、公告模块、企业论坛、云售后模块、生产模块、系统模块化同步模块等多种复杂业务功能。 有一些小伙伴很好奇最近更新的内容和智能制造有什么关系? 答:目前 Skyeye 整体在做重构,优先从底层的一些功能开始,所以现在大家看到的和智能制造的联系不是很大,也希望大家能够理解,一个大型的智能制造对底层的依赖性也是非常高的。 智能制造一体化 v3.9.6 发布,更新内容如下: 已完成测试的组件:输入框,下拉框,文本框,上传组件,枚举卡槽,文字分割线,编码规则,附件上传,数据字典卡槽,团队模板,部门信息,用户选择 已托管到表单布局的功能:角色管理,桌面管理,前台服务配置,编码管理,联系人管理(新增/编辑),CRM客户管理,CRM客户合同(新增/编辑),CRM客户商机(新增/编辑),CRM客户跟单(新增/编辑) 删...
- 下一篇
Fantastic-admin v2.9.0 发布
【基础版】 🚀Features 用户权限变更后,自动更新导航菜单和页面权限,无需刷新页面或者重新登录 🐞Bug Fixes 修复 axios baseURL 配置,解决构建后 baseURL 不生效的问题 【专业版】 🚀Features 用户权限变更后,自动更新导航菜单和页面权限,无需刷新页面或者重新登录 标签栏增加记忆功能,刷新页面不丢失标签页 🐞Bug Fixes 修复 axios baseURL 配置,解决构建后 baseURL 不生效的问题 修复登出时页面报错 增加 dropdown 组件外边框的临时解决方案 Fantastic-admin 一款开箱即用的 Vue 中后台管理系统框架 特点 丰富的布局与主题,覆盖市面上各种中后台应用场景,兼容 PC、平板和移动端 提供系统配置文件,轻松实现个性化定制 精心设计的动效,让每一处的动画都干净利落 根据路由配置自动生成导航栏 基于文件系统的路由 支持全方位权限验证 内置多级路由最佳缓存方案 轻松实现国际化多语言适配 提供接近于浏览器原生标签栏操作体验的标签页功能
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Red5直播服务器,属于Java语言的直播服务器
- CentOS7设置SWAP分区,小内存服务器的救世主
- CentOS7安装Docker,走上虚拟化容器引擎之路
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- CentOS关闭SELinux安全模块
- CentOS7,CentOS8安装Elasticsearch6.8.6
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- Linux系统CentOS6、CentOS7手动修改IP地址
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- CentOS8安装Docker,最新的服务器搭配容器使用