mysql comment on_记录:mysql中的case when|on duplicate key update|重复插入返回主键的用法...

本文介绍MySQL中的CASE函数使用方法,如何实现重复插入时更新数据,以及使用MyBatis获取插入后的主键ID。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1460000011383125

在平时的开发中不免接触到数据库,这里记录一些平时开发中遇到的细节问题,与大家共勉。

mysql中的条件控制:case函数

在操作数据库的开发中不免遇到一些类似if else的判断,这时候就用到了Case函数,首先我们用网上用了好多次的例子来看看它的用法:

case when sex = '1' then '男'

when sex = '2' then '女'

else '其他' end

利用这个格式我们可以就可以完成类似if else的操作,比如:

SELECT

SUM(

case

when V.IN_OUT = '2' then -AMOUNT

when V.IN_OUT = '1' then AMOUNT end) AMOUNT

FROM

tb_financial

怎么样,很简单吧!

mysql中重复插入时更新

为了防止数据重复插入报错,我们可以让重复插入主键相同的数据时改为更新这条数据。

我们使用mysql官网的例子:

INSERT INTO t1 (a,b,c) VALUES (1,2,3)

ON DUPLICATE KEY UPDATE c=c+1;

UPDATE t1 SET c=c+1 WHERE a=1;

按照官网的说法,如果列a被声明为UNIQUE并包含该值 1,则这两个语句具有类似的效果。当列b也是唯一的时候,则相当于下面这条sql:

UPDATE t1 SET c=c+1 WHERE a=1 OR b=2 LIMIT 1;

但是,并不建议ON DUPLICATE KEY UPDATE在具有多个唯一索引的表上使用。

MyBatis+MySQL 返回插入的主键ID

在使用Mybatis想返回插入的主键ID也很简单,只需要在insert的Mapper中添加useGeneratedKeys="true"和keyProperty="实体中主键属性名"两个属性:

INSERT INTO Tb_financial

(id,

amount,

comment)

VALUES

(#{id},

#{amount},

#{comment})

这样在调用此方法后实体中的主键值就会自动返回:

Financial financial = new Financial();

financial.setId("chenzhou");

financial.setAmount("xxxx");

financial.setComment("测试插入数据返回主键功能");

System.out.println("插入前主键为:"+financial.getId());

userDao.insertAndGetId(financial);//插入操作

System.out.println("插入后主键为:"+financial.getId());

本文作者: catalinaLi

本文链接: http://catalinali.top/2017/re...

版权声明: 原创文章,有问题请评论中留言。非商业转载请注明作者及出处。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值