Mybatis插入记录并返回MySQL自增主键
2024-10-12 14:22:38
mapper
Integer insertConfigAndGetId(CrawlerConfig config);
xml
<insert id="insertConfigAndGetId" parameterType="com.suning.epp.fmasosadmin.dmo.CrawlerConfig">
<selectKey keyProperty="id" order="AFTER" resultType="java.lang.Integer">
select LAST_INSERT_ID() as id
</selectKey>
insert into
T_CRAWLER_CONFIG(START_URL,PROCESSOR,PIPELINE_NAME,THREAD_NAME,RETRY_TIMES,SLEEP_TIME,CHARSET,HEADERS)
values
(#{startUrl},#{processor},#{pipelineName},#{threadNum},#{retryTimes},#{sleepTime},#{charset},#{headers})
</insert>
参数说明:
resultType:返回的主键类型
order:这可以被设置为 BEFORE 或 AFTER。如果设置为 BEFORE,那么它会首先选择主键,设置 keyProperty 然后执行插入语句。
如果设置为 AFTER,那么先执行插入语句,然后执行 selectKey 元素 。
keyProperty:selectKey 语句结果应该被设置的目标属性(对应参数中的主键的属性名)
注意:
取返回的主键名不能用
Integer cid = crawlConfigMapper.insertConfigAndGetId(config);
这样取到的值是插入影响的条数,而不是刚插入记录的主键值!!!
刚插入记录的主键值从刚插入记录的实体参数中取:
crawlConfigMapper.insertConfigAndGetId(config);
// 刚保存记录的主键值
Integer cid = config.getId();
最新文章
- 理解C++的inline函数
- Jmeter plugin jp@gc - PerfMon Metrics Collector
- 搭建Maven工程的时候,做单元测试,报ClassNotFoundException
- 第一发。。。codeforces 609 C Load Balancing 贪心
- [转]移动App测试中的最佳做法
- textarea中限制输入字符长度(实用版)
- 转载 How to Encrypt connection string in web.config
- Thinkphp twig
- POJ Oulipo (KMP)
- CentOS7: How to resolve curl#56 - ";Recv failure: Connection reset by peer";
- Eclipse 主题
- Linux简单版重要安装步骤
- [UVA-11100] The Trip
- Alpha冲刺-第三天
- 《剑指offer》第二十九题(顺时针打印矩阵)
- PYTHON实现识别图片
- java基础学习总结——面向对象2
- Excel 2010 如何快速统计一列中相同数值出现的个数 很不错
- MoreEffectiveC++Item35(异常)(条款9-15)
- Java 方法重载和多态