mybatis主键自增长
在数据库中建序列:SEQ_T_RESOURCE
第一种:会在传入该方法的的参数集合中添加主键元素,相当于:map.put("RES_ID",xxx);
<insert id="saveForImport" parameterType="map">
<selectKey keyProperty="RES_ID" order="BEFORE" resultType="string">
SELECT SEQ_T_RESOURCE.NEXTVAL AS RES_ID FROM DUAL
</selectKey>
INSERT INTO T_RESOURCE(
RES_ID,
RES_NO,
RES_NAME)
values(
#{RES_ID},
#{RES_NO},
#{RES_NAME,jdbcType=VARCHAR})
</insert>
第二种:不需要返回插入的主键值
<insert id="saveForImport" parameterType="map">
INSERT INTO T_RESOURCE(
RES_ID,
RES_NO,
RES_NAME)
values(
SEQ_T_RESOURCE.NEXTVAL,
#{RES_NO},
#{RES_NAME,jdbcType=VARCHAR})
</insert>
第三种:会在传入该方法的的参数集合中添加主键元素,相当于:map.put("RES_ID",xxx);
<insert id="doSaveTaskDetail" parameterType="map" >
insert into tb_cablecheck_taskdetail(
DETAIL_ID,
TASK_ID)
values
(SQP_TB_CABLECHECK_TASK_DETAIL.nextVAL,
#{TASK_ID},
#{INSPECT_OBJECT_ID})
<selectKey resultType="java.lang.Integer" order="AFTER" keyProperty="DETAIL_ID">
SELECT SQP_TB_CABLECHECK_TASK_DETAIL.CURRVAL FROM DUAL
</selectKey>
</insert>
第四种:
先写个方法,获取recordId,然后作为参数传入插入表的SQL
int recordId = checkOrderDao.getRecordId();
<select id="getRecordId" resultType="int">
select SEQ_TB_EQPRECORD.NEXTVAL from DUAL
</select>
<insert id="insertEqpRecord" parameterType="map">
insert into tb_cablecheck_record
(RECORD_ID,
EQP_ID,
EQP_NO,
EQP_NAME)
values
(#{recordId},
#{eqpId},
#{eqpNo},
#{eqpName})
</insert>
mybatis主键自增长的更多相关文章
- oracle,mybatis主键自增长
<insert id="insert" parameterType="resource"> <selectKey resultType=&qu ...
- Mybatis 操作数据库的主键自增长
本篇文章将研究mybatis 实现oracle主键自增的机制 首先我们看对于同一张student表,对于mysql,sql server,oracle中它们都是怎样创建主键的 在mysql中 crea ...
- mybatis配置oracle的主键自增长
引用自:https://hacpai.com/article/1405392025960 mysql.sqlserver等数据库本身带有主键自增长像auto_increment的功能可以直接使用 us ...
- MyBatis主键返回
在使用MyBatis做持久层时,insert语句默认是不返回记录的主键值,而是返回插入的记录条数:如果业务层需要得到记录的主键时,可以通过配置的方式来完成这个功能. 比如在表的关联关系中,将数据插入主 ...
- PowerDesigner 15设置mysql主键自动增长及基数
PowerDesigner 15设置mysql主键自动增长及基数 1.双击标示图,打开table properties->columns, 如图点击图标Customize Columns an ...
- sql server小技巧-自动添加时间与主键自增长
在敲机房收费系统的时候,遇到添加时间的时候总是通过vb端调用当前时间再添到sql server中,期间还有时因为添加时间格式的不统一导致一些小问题,现在才知道原来是自己孤陋寡闻,sql server ...
- Oracle实现主键自增长
-- 主键设置:xx_id number(24) primary key 1 create sequence XX_seq --序列名称 increment by 1 -- 每次加几个 start - ...
- oracle 主键自动增长
oracle 主键自动增长 2009-12-11 16:07:00| 分类: 数据库资料|字号 订阅 这几天搞Oracle,想让表的主键实现自动增长,查网络实现如下: create tabl ...
- MyBatis主键生成器SelectKeyGenerator(三)
前面两篇博客我们介绍了MyBatis主键生成器KeyGenerator(一)和MyBatis主键生成器Jdbc3KeyGenerator(二),接下来我们介绍SelectKeyGenerator, 如 ...
随机推荐
- 洛谷 P1076 寻宝 解题报告
P1076 寻宝 题目描述 传说很遥远的藏宝楼顶层藏着诱人的宝藏.小明历尽千辛万苦终于找到传说中的这个藏宝楼,藏宝楼的门口竖着一个木板,上面写有几个大字:寻宝说明书.说明书的内容如下: 藏宝楼共有\( ...
- CF1101D GCD Counting(数学,树的直径)
几个月的坑终于补了…… 题目链接:CF原网 洛谷 题目大意:一棵 $n$ 个点的树,每个点有点权 $a_i$.一条路径的长度定义为该路径经过的点数.一条路径的权值定义为该路径经过所有点的点权的 GC ...
- Java -- JDBC 学习--获取数据库链接
数据持久化 持久化(persistence): 把数据保存到可掉电式存储设备中以供之后使用.大多数情况下,特别是企业级应用,数据持久化意味着将内存中的数据保存到硬盘上加以”固化”,而持久化的实现过程大 ...
- [POI2010]KLO-Blocks——一道值得思考的题
题目大意: 给出N个正整数a[1..N],再给出一个正整数k,现在可以进行如下操作:每次选择一个大于k的正整数a[i],将a[i]减去1,选择a[i-1]或a[i+1]中的一个加上1.经过一定次数的操 ...
- 11:SSM框架下各个层的解释说明
具体见网址:http://blog.csdn.net/lutianfeiml/article/details/51864160
- SNP (Single Nucleotide Polymorphism), SNV ( single nucleotide variants ) , Indel (insertion-deletion) 的区别
SNP (Single Nucleotide Polymorphism):强调在一个群体中具有一定频率的变异,一般为二态性.比如G→C SNV ( single nucleotide variants ...
- 2范数和F范数的区别
2范数和F范数是不同的. 2范数表示矩阵或向量的最大奇异值,max(svd(X)) 而 F范数表示矩阵所有元素平方和的开方根 sqrt(∑_(x_(i,j∈X))▒x_(i,j)^2 )
- maveb安装与配置(win10)
转载:https://www.cnblogs.com/eagle6688/p/7838224.html 看了几篇博客,感觉这篇博客写的含金量最高了,因为我电脑的系统是win10的,所以配置有细微的差别 ...
- Arcgis api 离线部署
Arcgis api 离线部署 修改 文件一(init.js)位置:arcgis_js_v317_api\arcgis_js_api\library\3.17\3.17\init.js 将[HOSTN ...
- python---web框架本质(1)
总的来说php相对较为简单,但是内部封装太多,不利于对编程的更本质探索. 但是对于生产开发确实是一门不错的语言.python对于socket以及web框架的理解更加透彻 # coding:utf8 # ...