Mybatis 坑路5 -> Spring 与 MyBatis 整合 + 基于注解的 SQL 映射器

32 篇文章 0 订阅
5 篇文章 0 订阅

##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);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值