首页 技术 正文
技术 2022年11月19日
0 收藏 811 点赞 3,155 浏览 646 个字

MySQL 自4.1版以后开始支持INSERT … ON DUPLICATE KEY UPDATE语法

例如:

 id name sex age
 1 kathy male 23
 2 Javer famale 32
 3 Mike male 19

方法一:

INSERT INTO kk (id, name,sex)  VALUES(1,'kara','ssss') ON DUPLICATE KEY UPDATE id=1;

方法二:

REPLACE INTO kk(id, name,sex) VALUES (12,'','female'),(13,'Emily','femse');

总结如下:

  1. 如果表中不存在主键记录,replace和insert …. update都与insert是一样的特点。
  2. 如 果表中存在主键记录,replace相当于执行delete 和 insert两条操作,而insert …. update的相当于执行if exist do update else do insert操作。因此,如果replace填充的字段不全,则会导致未被更新的字段都会修改为默认值,并且如果有自增id的话,自增id会变化为最新的 值(这样如果是以自增id为标志的话可能导致记录丢失);而insert*update只是更新部分字段,对于未被更新的字段不会变化(不会强制修改为默 认值)。

多条记录操作:
     insert into t(a,b,c) values (‘a1′,’b1′,’c1’),(‘a2′,’b2′,’c2’)
   on duplicate key update t.c=values(t.c)

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,082
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,556
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,405
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,179
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,815
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,898