文档章节

Mybatis插入数据行ID生成策略

macwhirr
 macwhirr
发布于 2017/09/07 10:39
字数 338
阅读 2
收藏 0
点赞 0
评论 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  ;

© 著作权归作者所有

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

暂无相关文章

IDEA创建SpringMVC+Mybatis+Maven项目

视频如下(加载有点慢请见谅,服务器不太好): 视频

影狼 ⋅ 8分钟前 ⋅ 0

前阿里P8架构师:精准定制Java架构师学习计划!

可以说,Java是现阶段中国互联网公司中,覆盖度最广的研发语言,掌握了Java技术体系,不管在成熟的大公司,快速发展的公司,还是创业阶段的公司,都能有立足之地。 有不少朋友问,除了掌握J...

java高级架构牛人 ⋅ 11分钟前 ⋅ 0

zookeper学习

https://blog.csdn.net/u012152619/article/category/6470028

~少司命~ ⋅ 12分钟前 ⋅ 0

Spring MVC ,JSON,JQuery,不懂JQuery,跳过了

/spring-mvc-study/src/main/webapp/course_json.jsp <%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD ......

颖伙虫 ⋅ 13分钟前 ⋅ 0

2018上海云栖大会workshop-日志数据采集与分析对接

摘要: 日志数据采集与分析对接 课程描述 通过日志服务采集用户、数据库、业务等访问数据。演示对于业务日志分析与处理,程序日志查询与监控,打通日志与数据仓库对接案例。 日志种类 网站访...

阿里云云栖社区 ⋅ 13分钟前 ⋅ 0

mahout demo

package com.datamine.CollaborativeFiltering.mysql; import org.apache.mahout.cf.taste.impl.neighborhood.NearestNUserNeighborhood; import org.apache.mahout.cf.taste.impl.recommend......

xiaomin0322 ⋅ 15分钟前 ⋅ 0

red hat openstack 12配置要求

安装 openstack 之前,一般要规划整个系统中,到底要多少台机器来参与openstack, 根据rhosp12的官方文档: 最低要求是3台物理机,1台作为director,一台作为 controller ,一台作为computer....

tututu_jiang ⋅ 16分钟前 ⋅ 0

Rocket-Chip在GitHub上的各个源码

在github上通过搜索Rocket-chip可以得到36个结果:其中 https://github.com/freechipsproject/rocket-chip https://github.com/ucb-bar/riscv-boom https://github.com/ucb-bar/fpga-zynq (......

whoisliang ⋅ 21分钟前 ⋅ 0

【HAVENT原创】CentOS 6.5 下 Nginx 的安装与配置

nginx是轻量级的Web服务器、反向代理服务器及邮件服务器,具有占用内存少,并发能力强的优点,已被广泛应用。本文介绍目前最新版本 1.12.2 的安装。 各版本nginx下载地址:http://nginx.org/...

HAVENT ⋅ 27分钟前 ⋅ 0

查看linux系统重启之前的log -- last_kmsg

当 Linux Kernel 出现 BUG 的时候,后走入 panic flow,这个时候由于 Kernel 出现了严重的问题,adbd 也无法响应 adb 连接请求,这个时候想透过读取 Kernel Log Buffer 来看 Kernel Log 是不...

zyzzu ⋅ 28分钟前 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部