设为首页 收藏本站
查看: 1088|回复: 0

[经验分享] MyBatis框架

[复制链接]

尚未签到

发表于 2017-12-11 17:53:50 | 显示全部楼层 |阅读模式
  向数据库中插入数据时,大多数情况都会使用自增列或者UUID做为主键。主键的值都是插入之前无法知道的,但很多情况下我们在插入数据后需要使用刚刚插入数据的主键,比如向两张关联表A、B中插入数据(A的主键是B的外键),向A表中插入数据之后,向B表中插入数据时需要用到A的主键。
  比如添加一个用户,同时返回插入用户后得到的用户id:


  • /** * 添加用户信息 * @param user * @throws Exception */ public int insertUser(User user) throws Exception { SqlSession session=sqlSessionFactory.openSession(); session.insert("com.danny.mybatis.insertUser", user); session.commit(); return user.getUserId();//返回插入数据库后得到的用户id }
  这里总结一下mybatis插入数据时返回主键的4种情况:MySQL环境下主键自增、mysql环境下主键为uuid、mysql环境下主键自增、mysql环境下主键为uuid。
  以下全文均以User实体来举例说明,字段有userId、userName、sex、birthday、address 五个属性,其中userId有可能是int类型,也有可能是String类型。
  数据库为mysql
  主键为自增时(主键为数值类型且自增)
  利用mysql的LAST_INSERT_ID()方法获取插入记录的主键,select LAST_INSERT_ID()可以在插入数据后,查询并返回刚插入数据的主键(但是单独执行这条语句只会返回0)。
  

<insert parameterType="com.danny.mybatis.po.User">  
<selectKey keyProperty="userId" order="AFTER" resultType="java.lang.Integer">
  
select LAST_INSERT_ID()
  
</selectKey>
  
insert into T_USER(userName,birthday,sex,address) values (#{userName},#{birthday},#{sex},#{address})
  
</insert>
  

  parameterType:指定insert执行语句接收的参数类型为pojo(这里的user)。
  keyProperty:将查询到的主键值设置到parameterType指定对象的哪个属性。
  order:<selectKey> 标签内的sql语句相对于insert语句的执行顺序,AFTER表示select LAST_INSERT_ID() 这个语句将在insert语句之后执行。
  主键为UUID时(主键必须为字符类型)
  使用mysql的方法UUID()方法获取随机的UUID作为主键,select UUID()可以在插入数据前,生成随机的UUID并通过keyProperty赋值给将要插入记录的主键。
  

<insert parameterType="com.danny.mybatis.po.User">  
<selectKey keyProperty="userId" order="BEFORE" resultType="java.lang.String">
  
select UUID()
  
</selectKey>
  
insert into user(userId,userName,birthday,sex,address) values (#{id},#{userName},#{birthday},#{sex},#{address})
  
</insert>
  

  在上述代码中可以看到order 的属性值为BEFORE ,说明在插入之前就已经生成了UUID,并且已经把UUID赋值给user的id。
  背 景数据库为oracle:
  主键为自增时(主键为数值类型):
  在oracle中实现主键自增,需要先创建序列,相当于创建一个全局变量,用来存储对应表的主键的当前最大值(主键为数值类型时)。
  先为user表创建一个序列:
  CREATE SEQUENCE USER_ID_SEQ
  INCREMENT BY 1 -- 每次递增1
  START WITH 1 -- 从1开始
  MINVALUE 1 -- 最小值=1
  NOCYCLE; -- 不循环
  利用USER_ID_SEQ.NEXTVAL 获得要插入数据的主键:
  

<insert parameterType="com.danny.mybatis.po.User">  
<selectKey keyProperty="userId" order="BEFORE" resultType="java.lang.Integer">
  
select USER_ID_SEQ.NEXTVAL as userId from DUAL
  
</selectKey>
  
insert into T_USER(userId,userName,birthday,sex,address) values (#{userId},#{userName},#{birthday},#{sex},#{address})
  
</insert>
  

  主键为UUID时
  用oracle自带的SYS_GUID()方法获得随机的GUID作为主键:
  

<insert parameterType="com.danny.mybatis.po.User">  
<selectKey keyProperty="userId" order="BEFORE" resultType="java.lang.Integer">
  
select SYS_GUID() as userId from DUAL
  
</selectKey>
  
insert into T_USER(userId,userName,birthday,sex,address) values (#{userId},#{userName},#{birthday},#{sex},#{address})
  
</insert>

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-423069-1-1.html 上篇帖子: Oracle/MSSQL中通过关键字查找所有存储过程 下篇帖子: Linux环境解决Oracle 中文乱码
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表