当前位置:   article > 正文

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

insert ... on duplicate 返回主键id

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


mysql中的条件控制:case函数

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

case when sex = '1' then '男'  
     when sex = '2' then '女'  
     else '其他' end
  • 1
  • 2
  • 3

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

SELECT
    SUM(
    case 
    when V.IN_OUT = '2' then -AMOUNT
    when V.IN_OUT = '1' then AMOUNT end) AMOUNT
FROM
    tb_financial
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

怎么样,很简单吧!

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;
  • 1
  • 2
  • 3
  • 4

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

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

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

MyBatis+MySQL 返回插入的主键ID

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

<insert id="InsertTBFinancial" useGeneratedKeys="true" keyProperty="id">
    INSERT INTO Tb_financial
      (id,
       amount,
       comment)
    VALUES
      (#{id},
       #{amount},
       #{comment})
    </insert>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

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

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());  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/485215
推荐阅读
相关标签
  

闽ICP备14008679号