insert时候怎么处理主键?

  • 自己生成主键:

    insert的参数是一个对象(除了主键id其余字段都是前台传过来的);id是由另一个服务生成的,这个服务使用了UidGenerator的getUID方法。最后拼成一个完整的pojo给dao层使用。

  • 获取生成的主键

    • 对于支持主键自增的数据库(MySQL)

      <!-- useGeneratedKeys 设置为"true"表明 MyBatis 要获取由数据库自动生成的主键,keyColumn指定数据库主键,keyProperty指定 Java 实体类中对应的主键字段 -->
      <insert id="insertUser" useGeneratedKeys="true" keyProperty="userId" >
        insert into user(
        user_name, user_password, create_time)
        values(#{userName}, #{userPassword} , #{createTime, jdbcType= TIMESTAMP})
      </insert>
      
    • 对于不支持主键自增的数据库(Oracle)

      对于像Oracle这样的数据,没有提供主键自增的功能,而是使用序列的方式获取自增主键。

      可以使用<selectKey>标签来获取主键的值,这种方式不仅适用于不提供主键自增功能的数据库,也适用于提供主键自增功能的数据库。<selectKey>标签一般的用法:

      <insert id="insertUser" >
      <selectKey keyColumn="id" resultType="long" keyProperty="userId" order="BEFORE">
      SELECT USER_ID.nextval as id from dual
      </selectKey>
      insert into user(
      user_id,user_name, user_password, create_time)
      values(#{userId},#{userName}, #{userPassword} , #{createTime, jdbcType= TIMESTAMP})
      </insert>
      
      属性 描述
      keyProperty 实体里面的id,selectKey 语句结果应该被设置的目标属性。如果希望得到多个生成的列,也可以是逗号分隔的属性名称列表。
      keyColumn 数据库里面的id,匹配属性的返回结果集中的列名称。如果希望得到多个生成的列,也可以是逗号分隔的属性名称列表。
      resultType 结果的类型,MyBatis 通常可以推算出来。MyBatis 允许任何简单类型用作主键的类型,包括字符串。如果希望作用于多个生成的列,则可以使用一个包含期望属性的 Object 或一个 Map。
      order 值可为BEFORE 或 AFTER。如果是 BEFORE,那么它会先执行selectKey设置 keyProperty 然后执行插入语句。如果为AFTER则相反。
      statementType 使用何种语句类型,默认PREPARED。有STATEMENT,PREPARED 和 CALLABLE 语句的映射类型。
      • Oracle 数据库中的值要设置为 BEFORE ,这是因为 Oracle中需要先从序列获取值,然后将值作为主键插入到数据库中。

      • 如果Mysql 使用selectKey的方式获取主键,需要注意下面两点:

        order :AFTER

        获取递增主键值 :SELECT LAST_INSERT_ID()

posted @   大于昨天  阅读(703)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示