MyBatis JPA Extra v2.7 GA 发布
MyBatis JPA Extra对MyBatis进行了JPA扩展,旨在基于JPA 2.1的注释简化对单表CUID操作,根据JPA注释动态生成SQL语句;使用Interceptor实现数据库SELECT分页查询,适配多种数据库;另外提供mybatis-jpa-extra-spring-boot-starter简化SpringBoot集成。
MyBatis JPA Extra对MyBatis扩展JPA功能
1.基于JPA 2.1的注释简化CUID操作;
2.用Interceptor实现数据库SELECT分页查询;
3.提供mybatis-jpa-extra-spring-boot-starter,简化SpringBoot集成;
1、JavaBean注释简单
仅有6个注释
@GeneratedValue有4中策略
-
AUTO
snowflakeid
uuid
uuid.hex
serial
-
SEQUENCE
generator值为数据库序列名
-
IDENTITY
generator无,根据数据库自动生成方式
package org.apache.mybatis.jpa.test.entity; import java.io.Serializable; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.Table; import org.apache.mybatis.jpa.persistence.JpaBaseEntity; @Entity @Table(name = "STUDENTS") public class Students extends JpaBaseEntity implements Serializable{ private static final long serialVersionUID = -6928570405840778151L; @Id @Column @GeneratedValue(strategy=GenerationType.AUTO,generator="snowflakeid") //@GeneratedValue(strategy=GenerationType.SEQUENCE,generator="SEQ_MYBATIS_STUD") //@GeneratedValue(strategy=GenerationType.IDENTITY,generator="SEQ_MYBATIS_STUD") 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() { super(); } public get(){}; public void set(){}; //... }
2、单表新增、修改、删除、查询、分页查询
package org.apache.mybatis.jpa.test; import java.sql.Types; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Date; import java.util.List; import org.apache.mybatis.jpa.test.dao.service.StudentsService; import org.apache.mybatis.jpa.test.entity.Students; import org.apache.mybatis.jpa.util.WebContext; import org.junit.Before; import org.junit.Test; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; public class MyBatisTestRunner { private static final Logger _logger = LoggerFactory.getLogger(MyBatisTestRunner.class); public static ApplicationContext context; public static StudentsService service; @Test public void insert() throws Exception{ _logger.info("insert..."); Students student=new Students(); //student.setId("10024"); 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()); //service.remove(student.getId()); } @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("insert id " + student.getId()); } @Test public void find() throws Exception{ _logger.info("find..."); _logger.info("find by filter " + service.find(" StdNo = '10024' or StdNo = '10004'") ); _logger.info("find by filter with args " + service.find( " StdNo = ? or StdNo = ? ", new Object[]{"10024","10004"}, new int[]{Types.VARCHAR,Types.INTEGER} ) ); } @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 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 remove() throws Exception{ _logger.info("remove..."); Students student=new Students(); student.setId("921d3377-937a-4578-b1e2-92fb23b5e512"); service.remove(student.getId()); } @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); } @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); } @Test public void batchDeleteByIds() throws Exception{ _logger.info("batchDeleteByIds..."); service.deleteBatch("2"); service.deleteBatch("2,639178432667713536"); } @Test public void queryPageResults() throws Exception{ _logger.info("queryPageResults..."); Students student=new Students(); //student.setId("af04d610-6092-481e-9558-30bd63ef783c"); //student.setStdGender("M"); //student.setStdMajor(政治"); student.setPageSize(10); //student.setPageNumber(2); student.calculate(21); List<Students> allListStudents = service.queryPageResults(student).getRows(); for (Students s : allListStudents) { _logger.info("Students "+s); } } @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); List<Students> allListStudents = service.queryPageResults("queryPageResults1",student).getRows(); for (Students s : allListStudents) { _logger.info("Students "+s); } } @Test public void query() throws Exception{ _logger.info("findAll..."); List<Students> allListStudents =service.query(null); for (Students s : allListStudents) { _logger.info("Students "+s); } } @Test public void findAll() throws Exception{ _logger.info("findAll..."); List<Students> allListStudents =service.findAll(); for (Students s : allListStudents) { _logger.info("Students "+s); } } @Before public void initSpringContext(){ if(context!=null) return; _logger.info("init Spring Context..."); SimpleDateFormat sdf_ymdhms =new SimpleDateFormat("yyyy-MM-dd HH🇲🇲ss"); String startTime=sdf_ymdhms.format(new Date()); try{ MyBatisTestRunner runner=new MyBatisTestRunner(); runner.init(); }catch(Exception e){ e.printStackTrace(); } _logger.info("-- --Init Start at " + startTime+" , End at "+sdf_ymdhms.format(new Date())); } //Initialization ApplicationContext for Project public void init(){ _logger.info("Application dir "+System.getProperty("user.dir")); context = new ClassPathXmlApplicationContext(new String[] {"spring/applicationContext.xml"}); WebContext.applicationContext=context; service =(StudentsService)WebContext.getBean("studentsService"); } }
版本更新
代码优化
新增find方法,根据过滤器查询数据
新增insertBatch方法
新增deleteBatch方法
删除batchInsert方法
删除batchDelete方法
日志功能优化
缓存调整为caffeine
升级log4j2 2.17.0
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Kitex v0.1.0 版本发布,高性能 Go RPC 框架
Kitex v0.1.0 版本已经发布,这是一个Golang 微服务 RPC 框架,具有高性能、强可扩展的特点,在字节内部已广泛使用。如今越来越多的微服务选择使用 Golang,如果对微服务性能有要求,又希望定制扩展融入自己的治理体系,Kitex 会是一个不错的选择。 此版本更新内容包括: 功能 泛化调用 IDL 解析支持多 Service 暴露 SetSeqID 方法便于二进制泛化场景 server 侧使用 泛化 client 支持关闭,规避内存泄漏问题 日志 修改日志风格,使用 “key=value” 列出信息 使用 klog 作为全局的日志输出工具 使用全局的 default logger 日志打印更多 context 信息,例如 logId,方便问题排查 go func 传入服务信息用于 recover panic 后输出关键信息方便问题排查 Option 增加 NewThriftCodecDisableFastMode 方法,来关闭 FastWrite 和 FastRead Kitex server 支持端口复用 默认 RPC 超时设置为 0(在后续 PR 中,revert ...
- 下一篇
前端资源静默刷新报错无解?不如用这个方案来避坑
一、问题背景 想必不少同学在开发过程中都经历过以下场景: 测试人员提出一个Bug,你在进行修复和Resolve后,测试人员Reopen并备注问题依然存在。你在本地确定代码无误后,去测试环境复现,发现原来是前端资源缓存的问题。 运维部署项目后,测试人员进行复查发现项目接口存在异常,后端与运维排查半天,最后发现原来是因为前端缓存还是上一个版本的。 浏览器缓存提供展现信息加速力的同时也会给所有使用者带来一些illusion。有时候即便经验非常丰富的前端技术人员,也可能会被hoisting所骗。这种本地缓存滞后的问题,虽然经常性遇到但很少真正被解决。 例如:在给客户部署产品后,使用过程中接口频频出现 4xx 状态码,在进行排查后端服务,排查代理等方向花费较长时间进行试错,最后发现是所使用的前端资源是浏览器缓存导致,在新版本中接口进行了变动,但由于是缓存资源,它请求的是新版本后端服务中废弃资源的 URI。 二、传统方案 对网络基础了解比较充分的同学肯定会马上想到: 重启 nginx 服务器强制更新缓存。 我们都知道浏览器的缓存分为两种:强缓存和协商缓存。并且根据优先级缓存被存储介质分为worke...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- CentOS8编译安装MySQL8.0.19
- CentOS6,7,8上安装Nginx,支持https2.0的开启
- SpringBoot2整合Redis,开启缓存,提高访问速度
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- MySQL8.0.19开启GTID主从同步CentOS8
- SpringBoot2全家桶,快速入门学习开发网站教程
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7