首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql updateinsert常用

    https://blog.csdn.net/haluoluo211/article/details/77984451 本文主要内容: update更新,batch批量更新 insert 数据到表中...,将表中数据插入到另一个表中 insert ignore忽略重复数据插入报错问题 ---- update更新,batch批量更新 ---- set sql_safe_updates=0; # 常规update...update springdemo.users set pwd=nickname where id=id; 下面给一个stack overflow中,按照条件批量更新的示例: 将id=1的字段赋值为...insert 数据到表中,将表中数据插入到另一个表中 ---- 基本插入示例: INSERT INTO tb_name(col1, col2) VALUES ("hyq","M"); # 例如 insert...into teacher(name, age) values('jack ma', 32); 工作中,往往我们要把一个表中的数据插入到另一张表中: INSERT INTO tb_al_sample

    3.4K30

    INSERT ... ON DUPLICATE KEY UPDATE

    这种控制可以放在业务层,也可以放在数据库层,大多数数据库都支持这种需求,如Oracle的merge语句,再如本文所讲的MySQL中的INSERT ......可以在ON DUPLICATE KEY UPDATE后面使用VALUES(字段名)函数来表示即将插入的值,如果需要插入或更新多条数据,并且更新的字段需要根据其它字段来运算时,可以使用如下语句: INSERT...: INSERT INTO table (a,b,c) VALUES (1,2,3) ON DUPLICATE KEY UPDATE c=3;--1+2 INSERT INTO table (a,b...,c) VALUES (4,5,6) ON DUPLICATE KEY UPDATE c=9;--4+5        如果一个表中包含了一个自增的字段,使用INSERT ......ON DUPLICATE KEY UPDATE新增或修改t数据后,可以通过last_insert_id()方法返回最后自动生成的值,如果是多条,实际测试是返回第一条数据自增的值。

    1.7K00

    INSERT ... ON DUPLICATE KEY UPDATE Statement

    ON DUPLICATE KEY UPDATE语句 就像mysql官方文档中提到的那样,我们如果将a列设为UNIQUE唯一索引或者主键时,并且当前表已经存在了a=1的数据,对于这种情况,下面两条sql的结果是相等的...当然如果不满足上方条件,则会新增一条数据 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; 对于InnoDB引擎的表,此处的新增可能会触发自增列,但修改操作不会触发 如果上方的唯一索引再加一个b列,则上方第一条sql和下方sql结果相等 UPDATE...,也可以使用 LAST_INSERT_ID()函数获取自增后的值 我们还可以在ON DUPLICATE KEY UPDATE后方使用VALUES函数来获取上方INSERT语句中某列的值例如 INSERT...INTO t1 (a,b,c) VALUES (1,2,3),(4,5,6) ON DUPLICATE KEY UPDATE c=VALUES(a)+VALUES(b); 上面的sql和下面这条sql

    76530

    insert...on duplicate key update语法

    MySQL不常用的一个语法 今天周会上,同事提到了一个业务问题,场景大概是这样的,业务方的需求是查询一条语句在不在,如果在就给出一个update语句,更新这条记录,如果不在,就给出一个insert...基于这个问题,同事提出了insert...on duplicate key update这个办法,而我的第一反应是replace方法,因为我之前从来没用过insert...on duplicate key...test_1 set age=18 where id=1; 这就是insert...on duplicate key update语法的作用,可以分析到,当发生主键冲突的时候,可以直接进行update...使用这个方法可以替代业务方的那种2个SQL的写法,也能够解决数据的原子性问题。 需要注意的是,这个语法不是SQL的通用语法,而是MySQL特有的一种语法。...03 不同之处 有了上面的知识储备,这两条命令的不同之处就显而易见了,replace是删除记录,然后再重新insert,而insert...on duplicate key update是直接在该条记录上修改

    2.5K40

    insert ... on duplicate key update 和 replace into

    先说结论 insert ... on duplicate key update 和 replace into 执行成功之后返回的影响行数,是个比较小的主题,我们先说结论,然后再分析这两种 SQL 执行过程中计算影响行数的逻辑...update 字段列表 以 t_insert 表为例,i1 字段上有唯一索引,表中记录如下: 示例 SQL 如下: insert into t_insert(i1, i2) values (105,...999) on duplicate key update i2 = 205 示例 SQL 中,update i2 字段值和表中 i1 = 105 的记录的 i2 字段值一样。...t_insert 表中记录如下: 示例 SQL 如下: replace into t_insert(id, i1, i2) values (4, 105, 888) 示例 SQL 中,待插入记录的...执行过程分析 3.1 insert ... on duplicate key update insert duplicate 语句是 MySQL 对 SQL 标准的扩展,它有 2 种行为: 如果插入记录和表中记录不存在主键或唯一索引冲突

    1.7K40

    Mysql - insert into on duplicate key update 异常探究

    背景 场景: 向表admin插入一条数据,如果business_id字段如果有重复的,则is_update置为1 create_sql CREATE TABLE `admin` ( `id` bigint...执行sql insert into admin(business_id) values (12345) on duplicate key update is_update = 1; 3....发现问题 表中business_id有12345的重复数据,执行之后发现执行成功,但是该数据的is_update并没有改变。 4....执行过程是先确保insert语句可执行,之后再判断duplicate key。 insert操作异常反馈的重复字段如果不在sql中,则不会执行后续的update。 5....解决办法 在执行insert duplicate key语句的时候,尽量使用主键作为判断,主键的重复判断优先级比其他字段的unique key优先级高,所以在执行插入重复的时候能正常触发update

    1.8K20
    领券