MySQL中REPLACE INTO和INSERT INTO的区别分析
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL中REPLACE INTO和INSERT INTO的区别分析相关的知识,希望对你有一定的参考价值。
参考技术A 注意,除非表有一个PRIMARYKEY或UNIQUE索引,否则,使用一个REPLACE语句没有意义。该语句会与INSERT相同,因为没有索引被用于确定是否新行复制了其它的行。
[separator]
所有列的值均取自在REPLACE语句中被指定的值。所有缺失的列被设置为各自的默认值,这和INSERT一样。您不能从当前行中引用值,也不能在新行中使用值。如果您使用一个例如“SET
col_name
=
col_name
+
1”的赋值,则对位于右侧的列名称的引用会被作为DEFAULT(col_name)处理。因此,该赋值相当于SET
col_name
=
DEFAULT(col_name)
+
1。
为了能够使用REPLACE,您必须同时拥有表的INSERT和DELETE权限。
REPLACE语句会返回一个数,来指示受影响的行的数目。该数是被删除和被插入的行数的和。如果对于一个单行REPLACE该数为1,则一行被插入,同时没有行被删除。如果该数大于1,则在新行被插入前,有一个或多个旧行被删除。如果表包含多个唯一索引,并且新行复制了在不同的唯一索引中的不同旧行的值,则有可能是一个单一行替换了多个旧行。
受影响的行数可以容易地确定是否REPLACE只添加了一行,或者是否REPLACE也替换了其它行:检查该数是否为1(添加)或更大(替换)。
如果您正在使用C
API,则可以使用mysql_affected_rows()函数获得受影响的行数。
目前,您不能在一个子查询中,向一个表中更换,同时从同一个表中选择。
下文时算法的详细说明(此算法也用于LOAD
DATA…REPLACE):
1.
尝试把新行插入到表中
2.
当因为对于主键或唯一关键字出现重复关键字错误而造成插入失败时:
a.
从表中删除含有重复关键字值的冲突行
b.
再次尝试把新行插入到表中
使用格式如下:
REPLACE
[LOW_PRIORITY
|
DELAYED]
[INTO]
tbl_name
[(col_name,...)]
VALUES
(expr
|
DEFAULT,…),(…),…
或:
REPLACE
[LOW_PRIORITY
|
DELAYED]
[INTO]
tbl_name
SET
col_name=expr
|
DEFAULT,
…
或:
REPLACE
[LOW_PRIORITY
|
DELAYED]
[INTO]
tbl_name
[(col_name,...)]
SELECT
…
MySQL中的insert ignore into, replace into用法总结
MySQL replace into 有三种形式:
1. replace into tbl_name(col_name, ...) values(...)
2. replace into tbl_name(col_name, ...) select ...
3. replace into tbl_name set col_name=value, ...
1.insert ignore into
当插入数据时,如出现错误时,如重复数据,将不返回错误,只以警告形式返回。所以使用ignore请确保语句本身没有问题,否则也会被忽略掉。例如:
INSERT IGNORE INTO books (name) VALUES (‘MySQL Manual‘)
2.on duplicate key update
当primary或者unique重复时,则执行update语句,如update后为无用语句,如id=id,则同1功能相同,但错误不会被忽略掉。例如,为了实现name重复的数据插入不报错,可使用一下语句:
INSERT INTO books (name) VALUES (‘MySQL Manual‘) ON duplicate KEY UPDATE id = id
3.insert … select … where not exist
根据select的条件判断是否插入,可以不光通过primary 和unique来判断,也可通过其它条件。例如:
INSERT INTO books (name) SELECT ‘MySQL Manual‘ FROM dual WHERE NOT EXISTS (SELECT id FROM books WHERE id = 1)
4.replace into
如果存在primary or unique相同的记录,则先删除掉。再插入新记录。
REPLACE INTO books SELECT 1, ‘MySQL Manual‘ FROM books
本文参考自:https://www.cnblogs.com/sweet521/p/5730804.html,感谢源作者分享。
以上是关于MySQL中REPLACE INTO和INSERT INTO的区别分析的主要内容,如果未能解决你的问题,请参考以下文章
mysql中的replace into和insert into的效率问题
MySQL的replace into 与insert into on duplicate key update
MySQL的replace into 与insert into on duplicate key update
MySQL中的insert ignore into, replace into等的一些用法小结(转)