Mybatis@options注解属性useGeneratedKeys,keyProperty,keyColumn的使用

Posted 牧牛人Alec

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mybatis@options注解属性useGeneratedKeys,keyProperty,keyColumn的使用相关的知识,希望对你有一定的参考价值。

@option注解标签useGeneratedKeys=true表示使用数据库自动增长的主键,keyColumn用于指定数据库table中的主键,keyProperty用于指定传入对象的成员变量。

public interface VideoOrderMapper {

    /**
     * 查询用户是否购买过此商品
     * @param userId
     * @param videoId
     * @param state
     * @return
     */
    VideoOrder findByUserIdAndVideoIdAndState(@Param("user_id") int userId,@Param("video_id") int videoId,@Param("state") int state);

Springboot中 Mybatis 配置文件 Mapper参数
useGeneratedKeys=“true” keyProperty=“id”
useGeneratedKeys设置为 true 时,表示如果插入的表id以自增列为主键,则允许 JDBC 支持自动生成主键,并可将自动生成的主键id返回。
useGeneratedKeys参数只针对 insert 语句生效,默认为 false;

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="ren.redface.demo.mapper.VideoOrderMapper">

   <!--插入订单的接口;取值顺序不能错乱--> <insert id="saveOrder" useGeneratedKeys="true" keyColumn="id" keyProperty="id"> INSERT INTO `video_order` (`out_trade_no`, `state`, `create_time`, `total_fee`, `video_id`, `video_title`, `video_img`, `user_id`) VALUES (#{outTradeNo,jdbcType=VARCHAR},#{state,jdbcType=INTEGER},#{createTime,jdbcType=TIMESTAMP},#{totalFee,jdbcType=INTEGER}, #{videoId,jdbcType=INTEGER},#{videoTitle,jdbcType=VARCHAR},#{videoImg,jdbcType=VARCHAR},#{userId,jdbcType=INTEGER}) </insert>

</mapper>

 

参考:

Mybatis 参数 useGeneratedKeys ,keyColumn,keyProperty作用和用法

Mybatis中自动生成主键

以上是关于Mybatis@options注解属性useGeneratedKeys,keyProperty,keyColumn的使用的主要内容,如果未能解决你的问题,请参考以下文章

Java 注解自定义注解 ( 注解属性定义与赋值 )

注解之注解的属性

Java 注解自定义注解 ( 注解解析 )

java注解使用java获取注解的属性获取注解的字段值

java 注解处理器(AbstractProcessor) 获取到 指定注解的属性值 javapoet 如何使用这个值生成类?

@Transactional注解的rollbackFor属性