MyBatis实战——Oracle/MySQL写入数据后返回主键

1 篇文章 0 订阅
1 篇文章 0 订阅

 一、有自增主键的数据库(例如:MySQL/MSDB)

         这类数据库使用MyBatis官方说明中的useGeneratedKeys、keyProperty属性

         -- useGeneratedKeys,使用 JDBC 的 getGeneratedKeys 方法来取出由数据库内部生成的主键,默认值:false。

        -- keyProperty,和parameterType中指定的参数属性保持一致。

<insert id="addTotemUser" parameterType="com.totem.model.TotemUser"
            useGeneratedKeys="true" keyProperty="uId">
        INSERT INTO t_user(u_name, u_age) VALUES
        (
            #{uName},
            #{uAge}
        )
</insert>

      主键首先会被写入parameterType中的对应字段,然后再进行入库操作,那么在入库完成之后我们就可以通过传入的javaBean获取主键,而写入语句本身返回的依然是受影响的数据库行数

  实例如下图所示:

public void addTotemUser() {
        TotemUser totemUser = new TotemUser();
        totemUser.setuName("杨玉环");
        totemUser.setuAge(18);

        totemUserMapper.addTotemUser(totemUser);
        System.out.println("返回的主键是:"+totemUser.getuId());
    }
​

二、没有自增主键的数据库(例如:oracle)

        Oracle数据库通过序列可以实现主键的生成,那么在写入数据时可以通过selectKey在写入数据之前查询序列,并将序列填入parameterType传入的javaBean中。

        此处的查询可以通过order属性进行设置(BEFORE/AFTER)是在INSERT之前还是之后。

        此处需要注意的是,如果Mapper中的参数设置了@Param("xxx")别名,那么keyProperty也需要添加别名,否则无法返回主键

  实例如下图所示:

<insert id="addUserTest" parameterType="com.totem.model.UserTest">
        <selectKey keyProperty="user.id" resultType="java.lang.Integer" order="BEFORE">
            SELECT seq_user_test.nextval FROM dual
        </selectKey>
        INSERT INTO user_test(ID, u_name, u_age, u_address, u_tele)
        VALUES
            (#{user.id}, #{user.uName}, #{user.uAge}, #{user.uAddress}, #{user.uTele})
</insert>
Integer addUserTest(@Param("user") UserTest userTest);

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis Plus是基于MyBatis的一个增强工具,通过提供更简洁、更方便的API,简化了对数据库的操作。相比于原生的MyBatisMyBatis Plus提供了更丰富的功能和更高效的性能。而OracleMySQL都是常见的关系型数据库,它们在底层实现原理和语法特性上有一些不同。 对于双数据源的配置,可以通过MyBatis Plus的多数据源配置来实现。首先,需要在配置文件中定义两个不同的数据源,分别对应OracleMySQL。可以使用不同的dataSource和transactionManager配置来指定每个数据源的连接和事务管理。 然后,在代码中使用@DS注解来指定具体是使用哪个数据源。@DS注解可以标记在类级别和方法级别,用来指定使用的数据源。例如,@DS("oracle")标记在类级别上,表示该类中的所有方法都使用Oracle数据源,而@DS("mysql")标记在方法级别上,表示该方法使用MySQL数据源。 通过这样的配置,就可以实现在同一个应用中同时使用OracleMySQL数据源。在使用的过程中,可以根据业务需求灵活选择具体使用的数据库。同时,MyBatis Plus还提供了很多便捷的方法和功能,可以更方便地进行数据库操作。 总之,通过MyBatis Plus的多数据源配置,可以很方便地实现OracleMySQL数据源的使用。这样的配置对于一些需要同时操作多个数据库的应用来说非常有用,可以满足不同业务需求的多样性。使用MyBatis Plus可以提高开发效率和代码质量,使数据库操作变得更简单和高效。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值