MyBatis JPA Extra,MyBatis JPA 擴展 v2.2 發布

2020-12-24 開源中國

MyBatis JPA Extra

MyBatis JPA Extra對MyBatis進行了JPA擴展,旨在基於JPA 2.1的注釋簡化對單表CUID操作,根據JPA注釋動態生成SQL語句;使用Interceptor實現資料庫SELECT分頁查詢,適配多種資料庫;另外提供mybatis-jpa-extra-spring-boot-starter簡化SpringBoot集成。

相關資源

MyBatis網站

MyBatis GitHub源碼

1、JavaBean注釋簡單

只支持6個注釋

  • @Entity
  • @Table
  • @Column
  • @Id
  • @GeneratedValue
  • @Transient

@GeneratedValue有3中策略

  1. AUTO

    uuid

    uuid.hex

    serial

  2. SEQUENCE

    generator值為資料庫序列名

  3. IDENTITY

    generator無,根據資料庫自動生成方式

package org.apache.mybatis.jpa.test.domain;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.JpaBaseDomain;/* ID varchar(40) not null, NAME varchar(60) not null, STATUS char(1) null, CREATEBY varchar(40) null, CREATEDATE date null, UPDATEBY varchar(40) null, UPDATEDATE date null, constraint PK_ROLES primary key clustered (ID) *//** * @author Crystal.Sea * */@Entity@Table(name = "STUDENTS") public class Students extends JpaBaseDomain implements Serializable{ /** * */ private static final long serialVersionUID = -6928570405840778151L; @Id @Column @GeneratedValue(strategy=GenerationType.AUTO,generator="serial") //@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; public Students() { super(); } public String getStdNo() { return stdNo; } public void setStdNo(String stdNo) { this.stdNo = stdNo; } public String getStdName() { return stdName; } public void setStdName(String stdName) { this.stdName = stdName; } public String getStdGender() { return stdGender; } public void setStdGender(String stdGender) { this.stdGender = stdGender; } public int getStdAge() { return stdAge; } public void setStdAge(int stdAge) { this.stdAge = stdAge; } public String getStdMajor() { return stdMajor; } public void setStdMajor(String stdMajor) { this.stdMajor = stdMajor; } public String getStdClass() { return stdClass; } public void setStdClass(String stdClass) { this.stdClass = stdClass; } public String getId() { return id; } public void setId(String id) { this.id = id; } @Override public String toString() { return "Students [stdNo=" + stdNo + ", stdName=" + stdName + ", stdgender=" + stdGender + ", stdAge=" + stdAge + ", stdMajor=" + stdMajor + ", stdClass=" + stdClass + "]"; }}

2、單表新增、修改、刪除、查詢

package org.apache.mybatis.jpa.test;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.domain.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.setStdNo("10024"); student.setStdGender("M"); student.setStdName("司馬昭"); student.setStdAge(20); student.setStdMajor("政治"); student.setStdClass("4"); service.insert(student); Thread.sleep(1000); service.remove(student.getId()); } @Test public void get() throws Exception{ _logger.info("get..."); Students student=service.get("921d3377-937a-4578-b1e2-92fb23b5e512"); _logger.info("Students "+student); } @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.batchDelete(idList); } @Test public void findAll() throws Exception{ _logger.info("findAll..."); _logger.info("findAll "+service.findAll()); } @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("init ..."); context = new ClassPathXmlApplicationContext(new String[] {"spring/applicationContext.xml"}); WebContext.applicationContext=context; service =(StudentsService)WebContext.getBean("studentsService"); } }

3、支持分頁查詢

package org.apache.mybatis.jpa.test;import java.util.ArrayList;import java.util.List;import org.apache.mybatis.jpa.test.dao.service.StudentsService;import org.apache.mybatis.jpa.test.domain.Students;import org.apache.mybatis.jpa.util.WebContext;import org.junit.Before;import org.junit.Test;import org.junit.runner.RunWith;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.boot.test.context.SpringBootTest;import org.springframework.context.ApplicationContext;import org.springframework.test.context.junit4.SpringRunner;@RunWith(SpringRunner.class)@SpringBootTest(classes = MybatisJpaApplication.class)public class MybatisJpaApplicationTest{ private static final Logger _logger = LoggerFactory.getLogger(MybatisJpaApplicationTest.class); @Autowired StudentsService studentsService; @Autowired org.apache.ibatis.session.SqlSessionFactory SqlSessionFactory; @Autowired private ApplicationContext applicationContext; @Before public void before() { _logger.info("---------------- before"); WebContext.applicationContext=applicationContext; } @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"); studentsService.insert(student); Thread.sleep(1000); studentsService.remove(student.getId()); } @Test public void get() throws Exception{ _logger.info("get..."); Students student=studentsService.get("921d3377-937a-4578-b1e2-92fb23b5e512"); System.out.println("Students "+student); _logger.info("Students "+student); } @Test public void remove() throws Exception{ _logger.info("remove..."); Students student=new Students(); student.setId("921d3377-937a-4578-b1e2-92fb23b5e512"); studentsService.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"); studentsService.batchDelete(idList); } @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); List<Students> allListStudents = studentsService.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 = studentsService.queryPageResults("queryPageResults1",student).getRows(); for (Students s : allListStudents) { _logger.info("Students "+s); } } @Test public void findAll() { _logger.info("---------------- ALL"); List<Students> allListStudents=studentsService.findAll(); for (Students s : allListStudents) { _logger.info("Students "+s); } }}package org.apache.mybatis.jpa.test;import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceBuilder;import javax.sql.DataSource;import org.springframework.beans.factory.annotation.Value;import org.springframework.boot.context.properties.ConfigurationProperties;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.context.annotation.Primary;@Configurationpublic class MybatisJpaConfig { private int port; public int getPort() { return port; } public void setPort(int port) { this.port = port; } @Bean @Primary @ConfigurationProperties("spring.datasource") public DataSource dataSource() { return DruidDataSourceBuilder.create().build(); }}

4、映射文件配置

<mapper namespace="org.apache.mybatis.jpa.test.dao.persistence.StudentsMapper" > <sql id="sql_condition"> WHERE 1 = 1 <if test="id != null"> AND ID = '${id}' </if> <if test="stdName != null and stdName != '' "> AND STDNAME like '%${stdName}%' </if> <if test="stdGender != null and stdGender != '' "> AND STDGENDER = #{stdGender} </if> <if test="stdMajor != null"> <![CDATA[AND STDMAJOR = #{stdMajor}]]> </if> </sql> <select id="queryPageResults" parameterType="Students" resultType="Students"> SELECT ID , STDNO , STDNAME , STDGENDER , STDAGE , STDMAJOR , STDCLASS FROM STUDENTS <include refid="sql_condition"/> </select> <select id="queryPageResults1" parameterType="Students" resultType="Students"> SELECT ID , STDNO , STDNAME , STDGENDER , STDAGE , STDMAJOR , STDCLASS FROM STUDENTS <include refid="sql_condition"/> </select> <select id="queryBy" parameterType="Students" resultType="Students"> SELECT ID , STDNO , STDNAME , STDGENDER , STDAGE , STDMAJOR , STDCLASS FROM ROLES <include refid="sql_condition"/> </select> <delete id="delete" parameterType="Students" > DELETE FROM STUDENTS WHERE ID=#{id} </delete>

5、SpringBoot配置

spring.main.web-application-type=NONE#spring.datasource.username=rootspring.datasource.password=maxkeyspring.datasource.url=jdbc:mysql://localhost/test?autoReconnect=true&characterEncoding=UTF-8&serverTimezone=UTCspring.datasource.driver-class-name=com.mysql.jdbc.Driverspring.datasource.type=com.alibaba.druid.pool.DruidDataSourcemybatis.type-aliases-package=org.apache.mybatis.jpa.test.domainmybatis.mapper-locations=classpath*:/org/apache/mybatis/jpa/test/dao/persistence/xml/mysql/*.xmlmybatis.table-column-escape=true#mybatis.table-column-escape-char=`

相關焦點

  • 國人鍾情於Mybatis,而老外卻喜歡Hibernate/JPA,為啥?
    2.簡單,學習成本低小公司需要大量入門級的程式設計師,像大神甚至一個都請不起,請問大神們那些牛b框架哪個更快讓菜鳥們上手,降低公司學習成本。注意這個成本會一直跟隨公司,想必大神們創業直接前後端分離了,畢竟錢嘛多的是。
  • 為啥國人偏愛Mybatis,而老外喜歡Hibernate/JPA呢?
    2.簡單,學習成本低 小公司需要大量入門級的程式設計師,像大神甚至一個都請不起,請問大神們那些牛 b 框架哪個更快讓菜鳥們上手,降低公司學習成本。注意這個成本會一直跟隨公司,想必大神們創業直接前後端分離了,畢竟錢嘛多的是。
  • 為啥國人偏愛 Mybatis,而老外喜歡 Hibernate/JPA 呢?
    2.簡單,學習成本低 小公司需要大量入門級的程式設計師,像大神甚至一個都請不起,請問大神們那些牛 b 框架哪個更快讓菜鳥們上手,降低公司學習成本。注意這個成本會一直跟隨公司,想必大神們創業直接前後端分離了,畢竟錢嘛多的是。
  • mybatis-plus 2.1.8-SNAPSHOT 發布,代號:翻車魚
    mybatis-plus 是一款 mybatis 動態 SQL 自動注入 mybatis 增刪改查 CURD&nbsp;操作中間件。
  • 小學妹問:Mybatis常見註解有哪些?
    org.mybatis.spring.annotation.MapperScan使用方式@SpringBootApplication@MapperScan("com.tian.mybatis.mapper")public class Application {}
  • 乾貨|一文讀懂 Spring Data Jpa!
    JPA的供應商JPA 的目標之一是制定一個可以由很多供應商實現的 API,Hibernate 3.2+、TopLink 10.1+ 以及 OpenJPA 都提供了 JPA 的實現,Jpa 供應商有很多,常見的有如下四種:HibernateJPA 的始作俑者就是 Hibernate 的作者,Hibernate 從 3.2 開始兼容 JPA。
  • 從0 開始手寫一個 Mybatis 框架,三步搞定!
    MyBatis框架的核心功能其實不難,無非就是動態代理和jdbc的操作,難的是寫出來可擴展,高內聚,低耦合的規範的代碼。本文完成的Mybatis功能比較簡單,代碼還有許多需要改進的地方,大家可以結合Mybatis源碼去動手完善。
  • 高效Java Web 應用開發框架 JessMA v3.2.2 正式發布
    ★ 高度擴展:JessMA 通過的 plug-in 機制可以靈活擴展,JessMA 發布包中自帶的 jessma-ext-rest 和 jessma-ext-spring 均以插件的形式提供,用戶可根據需要加載或卸載這些插件。應用程式開發者也可以根據實際需要編寫自定義插件來擴展 JessMA。
  • MyBatis動態SQL(認真看看, 以後寫SQL就爽多了)
    2.1 在 WHERE 條件中使用 if 標籤這是常見的一種現象, 我們在進行按條件查詢的時候, 可能會有多種情況。2.1.1 查詢條件根據輸入的學生信息進行條件檢索2.1.2 動態 SQL接口函數    /**     * 根據輸入的學生信息進行條件檢索     * 1.
  • 「mybatis-plus」什麼是樂觀鎖?如何實現「樂觀鎖」
    或者實在要2個同時更新,那也只能有一個成功,這樣也沒異議。二、MP來實現樂觀鎖樂觀鎖的實現,通過增加一個欄位,比如version,來記錄每次的更新。1.在實體類裡增加對於的欄位,並且加上自動填充(你也可以每次手動填充)2. 配置插件為了便於管理,可以見一個包,用於存放各種配置類,順便把配置在啟動類裡的mapper掃描也換到這裡來。
  • Cocos Creator v2.1.2 正式發布
    自 Cocos Creator 2.1.0 發布之後,經過半年的更新迭代,版本已經趨於穩定,目前 2.1 的新增用戶已經佔據主流。
  • Svelte v2 已經過時了!
    大約是一年之前,我們首次在 Svelte 的 issue 跟蹤器上討論過 v2 版本,現在是時候進行一些重大變更了。我們的座右銘是「循序漸進,破舊立新」。……好吧,我錯了,看來我要改過自新了。這篇博文闡述了新版本的變化,都變了哪些地方、為什麼要變以及應對的策略。
  • ToonTrackEZDrummer2VST全套擴展音色打擊樂軟音源
    每首歌還配有整首歌曲的Jamtrack,從開始到結束。    在Chris的MIDI庫中,他在重新回顧了他的許多精選集中最好的錄音之後製作了他的專利節奏型。! O4 _  U8 o( v- I  z+ swww.audioapp.cn  audio app