文档章节

Mybatis插入数据行ID生成策略

macwhirr
 macwhirr
发布于 2017/09/07 10:39
字数 338
阅读 2
收藏 0

Oracle:

<insert id="insert" parameterType="vo.Category">

<selectKey resultType="java.lang.Short" order="BEFORE" keyProperty="id">

SELECT SEQ_TEST.NEXTVAL FROM DUAL

</selectKey>

insert into category (id,name_zh, parent_id,

show_order, delete_status, description

)

values (
#{id,jdbcType=NUMBER},

#{nameZh,jdbcType=VARCHAR},

#{parentId,jdbcType=NUMBER},

#{showOrder,jdbcType=NUMBER},

#{deleteStatus,jdbcType=NUMBER},

#{description,jdbcType=VARCHAR}

)

</insert>

MySQL:

针对自增主键的表,在插入时不需要主键,而是在插入过程自动获取一个自增的主键,比如MySQL,可以采用如下两种配置方式:

<insert id="insert" parameterType="vo.Category" useGeneratedKeys="true" keyProperty="id">

insert into category (id,name_zh, parent_id,

show_order, delete_status, description

)

values (
#{id,jdbcType=INTEGER},

#{nameZh,jdbcType=VARCHAR},

#{parentId,jdbcType=INTEGER},

#{showOrder,jdbcType=INTEGER},

#{deleteStatus,jdbcType=BIT},

#{description,jdbcType=VARCHAR}

)

</insert>

<insert id=" insert " parameterType="vo.Category">

<selectKey resultType="java.lang.Short" order="AFTER" keyProperty="id">

SELECT LAST_INSERT_ID() AS id

</selectKey>

insert into category (id,name_zh, parent_id,

show_order, delete_status, description

)

values (
#{id,jdbcType=INTEGER},

#{nameZh,jdbcType=VARCHAR},

#{parentId,jdbcType=INTEGER},

#{showOrder,jdbcType=INTEGER},

#{deleteStatus,jdbcType=BIT},

#{description,jdbcType=VARCHAR}

)

</insert>

UUID:

在Oracle中:

<insert id="insert" parameterType="com.xxx.SystemDepartment">

    <selectKey keyProperty="id" resultType="String" order="BEFORE">

        select sys_guid() from dual

    </selectKey>

    insert into SYSTEM_DEPARTMENT (ID,DEPNAME, SUPERID, SORT, STATE)

    values ( #{id,jdbcType=VARCHAR},#{depname,jdbcType=VARCHAR},

    #{superid,jdbcType=DECIMAL}, #{sort,jdbcType=DECIMAL},

    #{state,jdbcType=DECIMAL})

</insert>

在Mysql中:

<insert id="insert" parameterType="com.xxx.SystemDepartment">

    <selectKey keyProperty="id" resultType="String" order="BEFORE">

        SELECT UUID()

    </selectKey>

    insert into SYSTEM_DEPARTMENT (ID,DEPNAME, SUPERID, SORT, STATE)

    values ( #{id,jdbcType=VARCHAR},#{depname,jdbcType=VARCHAR},

    #{superid,jdbcType=INTEGER}, #{sort,jdbcType=INTEGER},

    #{state,jdbcType=INTEGER})

</insert>

注:UUID如不需要连字符'-'可以使用数据库函数进行处理,如mysql:  select  replace(uuid(),'-','')   UUID  ;

本文转载自:https://my.oschina.net/boonya/blog/692232

共有 人打赏支持
macwhirr
粉丝 0
博文 3
码字总数 222
作品 0
朝阳
程序员

暂无文章

RedHat已更改其开源许可规则

对于编程圈外的人来说,软件许可证似乎并不重要,但是,在开源领域,开源许可是非常重要的。 因此,领先的Linux公司Red Hat宣布了一件大事,所有新的由Red Hat发起的使用GNU通用公共许可证(...

linux-tao
7分钟前
0
0
游戏化策划的反馈机制

简评:如何低成本地设计游戏化活动运营方案 当项目活动组采用游戏化机制来设计活动时,往往会犯一个错误 —— 以为物质奖励(金钱或实物)就是终极奖励。然后一次又一次的证据显示,有形奖励...

极光推送
9分钟前
0
0
PHP "延迟静态绑定" 功能,static

从这个名字的定义提取出两个关键点,第一点静态,也就是说这个功能只适用于静态属性或静态方法。 第二点延迟绑定,这个根据下面代码就可以很好的理解 class A{ static $name = "Tom";...

nsns
13分钟前
1
0
《看图轻松理解数据结构与算法系列》导引贴

最近学习数据结构,遇到一个很喜欢的博主,他的文章图文并茂,理解起来很容易。特此开贴记录,方便反复阅读。 博主主页 https://juejin.im/user/57c3970f79bc440063e58518/posts?sort=popul...

科陆李明
50分钟前
1
0
20.27 分发系统介绍~ 20.30 expect脚本传递参数

分发系统介绍分发系统-expect讲解(也就是一个分发的脚本)场景:业务越来越大,网站app,后端,编程语言是php,所以就需要配置lamp或者lnmp,最好还需要吧代码上传到服务器上;但是因...

洗香香
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部