1. 程式人生 > >Mybatis 坑路5 -> Spring 與 MyBatis 整合 + 基於註解的 SQL 對映器

Mybatis 坑路5 -> Spring 與 MyBatis 整合 + 基於註解的 SQL 對映器

##Spring 與 MyBatis 整合 + 基於註解的 SQL 對映器

依賴的 Jar 包

  Mybatis 與 Spring 依賴的 Jar 包如下:

mybatis-3.3.0.jar
mybatis-spring-1.2.3.jar
SpringFramework 的相關 jar
Commons-logging.jar
資料庫連線池的相關 jar(dbcp 或 c3p0 或 durid)

配置 MyBatis Beans

  可以使用 @Insert 註解來定義一個 INSERT 對映語句:

@Insert("INSERT INTO STUDENTS(STUD_ID,NAME,EMAIL,ADDR_ID,PHONE)VALUES(#{studId},#{name},#{email},#{address.addrId},#{phone})")
int insertStudent(Student student);

  如果在插入資料的時候需要自動生成主鍵,可以使用 @Options 註解的 userGeneratedKeys 和 keyProperty 屬性讓資料庫產生 auto_increment(自增長)然後將生成的值設定到輸入引數物件的屬性中。

@Insert("INSERT INTO STUDENTS(NAME,EMAIL,ADDR_ID,PHONE)VALUES(#{name},#{email},#{address.addrId},#{phone})")
@Options(useGeneratedKeys = true,keyProperty = "studId")
int insertStudent(Student student);

對映語句

  有一些資料庫如 Oracle,並不支援 AUTO_INCREMENT 列屬性,塔使用序列(SEQUENCE)來產生主鍵的值。使用 @SelectKey 註解來為任意 SQL 語句來指定主鍵值,作為主鍵列的值。

@Insert("INSERT INTO STUDENTS(sTUD_ID,NAME,EMAIL,ADDR_ID,PHONE)VALUES(#{studId},#{name},#{email},#{address.addrId},#{phone})")
@SelectKey(statment="SELECT STUD_ID_SEQ.NEXTVAL FROM DUAL",keyProperty="studId",resultType=int.class,before=true)
int insertStudent(Student student);

  可以使用 @Delete 註解來定義一個 DELETE 對映語句,如下所示:

@Delete("DELETE FROM STUDENTS WHERE STUD_ID = #{studId}")
int deleteStudent(int studId);

  可以使用 @Select 註解來定義一個 SELECT 對映語句

@Select("SELECT STUD_ID AS STUDID,NAME,EMAIL,PHONE FROM STUDENTS WHERE STUD_ID=#{studId}")
Student findStudentById(Integer studId);