mybaties配置中useGeneratedKeys属性

其实useGeneratedKeys简单来说就是实体类获取数据库中对应表的自增主键值,这样数据库表数据才能与实体类数据一一对应。就是实体类ID获取数据表ID

一、在mybatis-config配置文件中配置useGeneratedKeys

作用:与mybatis的mapper文件中的useGeneratedKeys=true相对应(详情见下方的mapper文件配置)

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
    PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- 针对数据库的表格配置 -->
<!-- 配置全局属性 -->
  <settings>
  <!-- 使用jdbc的 getGeneratedKeys获取数据库自增主键值,
  就是当mybatis-dao文件中的SQL语句中useGeneratedKeys=true时,就是可以将数据库自增的主键值ID自动赋值给实体类ID-->
    <setting name="useGeneratedKeys" value="true"/>
    
    <!-- 可以用列别名替代列字段名,默认:true -->
    <setting name="useColumnLabel" value="true"/>
    
    <!-- 开启驼峰命名转换:table(create_time)转换为Entity{createTime} -->
    <setting name="mapUnderscoreToCamelCase" value="true"></setting>
  </settings>

</configuration>

二、mapper文件的useGeneratedKeys属性配置

<!-- useGeneratedKeys表示将当前主键值自动赋值给实体类ID-->
    <!--keyColumn为数据库主键  -->
    <!-- 将数据库主键值自动赋值到shop实体类中的shopId属性 -->
    <!--parameterType传入的参数类型  -->
    <!-- 不加parameterType属性也行,这个属性是可选的,因为 MyBatis 可以通过 TypeHandler 推断出具体传入语句的参数 。
    但是最好加上parameterType属性,因为这样可以提高代码的可读性
    -->
    <insert id="insertShop" useGeneratedKeys="true" keyColumn="shop_id" keyProperty="shopId" parameterType="com.imooc.o2o.entity.Shop">
    INSERT INTO
    tb_shop(owner_id,area_id,shop_category_id,
    shop_name,shop_desc,shop_addr,phone,shop_img,priority,create_time,last_edit_time,enable_status,advice)
   
    <!-- 将shop实体类中的成员变量属性值插入到数据库当中,前面三个是另外三个实体类的id,采用的是OGNL表达式,详情见mybatis基础版的笔记 -->
    VALUES(#{owner.userId},#{area.areaId},#{shopCategory.shopCategoryId},
    #{shopName},#{shopDesc},#{shopAddr},#{phone},#{shopImg},#{priority},#{createTime},#{lastEditTime},#{enableStatus},#{advice})
    </insert>

个人原创,若需转载,请注明出处!!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值