专栏/MySQL中 replace与replace into的区别与使用方法(干货分享)

MySQL中 replace与replace into的区别与使用方法(干货分享)

2020年12月24日 08:49--浏览 · --点赞 · --评论
沐歌爱编程
粉丝:1.2万文章:428

Mysql replace与replace into都是经常会用到的功能;replace其实是做了一次update操作,而不是先delete再insert;而replace into其实与insert into很相像,但对于replace into,假如表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。

replace是mysql 里面处理字符串比较常用的函数,可以替换字符串中的内容。类似的处理字符串的还有trim截取操作,这里就不在多说。

replace into 主要作用类似insert插入操作。主要的区别是replace会根据主键或者唯一索引检查数据是否存在,如果存在就先删除在更新。


例子:


采用上面的方式插入二条记录,insert into 会提示错误:1062 - Duplicate entry ‘a' for key ‘idx_name', Time: 0.001000s。使用replace into则会正常执行,只是id自增长1。

ps: replace into 中into关键字可以省略的,看起来一样,使用有点区别。

mysql replace用法

1.replace into 

replace into table (id,name) values('1','aa'),('2','bb') 

此语句的作用是向表table中插入两条记录。如果主键id为1或2不存在 

就相当于 

insert into table (id,name) values('1','aa'),('2','bb') 

如果存在相同的值则不会插入数据

2.replace(object,search,replace) 

把object中出现search的全部替换为replace 

select replace('www.jb51.net','w','Ww')--->WwWwWw.jb51.net 

例:把表table中的name字段中的aa替换为bb 

update table set name=replace(name,'aa','bb')

REPLACE的运行与INSERT很相像。如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。

注意,除非表有一个PRIMARY KEY或UNIQUE索引,否则,使用一个REPLACE语句没有意义。该语句会与INSERT相同,因为没有索引被用于确定是否新行复制了其它的行。


所有列的值均取自在REPLACE INTO语句中被指定的值。所有缺失的列被设置为各自的默认值,这和INSERT INTO一样。您不能从当前行中引用值,也不能在新行中使用值。如果您使用一个例如“SET col_name = col_name + 1”的赋值,则对位于右侧的列名称的引用会被作为DEFAULT(col_name)处理。因此,该赋值相当于SET col_name = DEFAULT(col_name) + 1。

使用REPLACE INTO,必须拥有表的INSERT和DELETE权限。

REPLACE语句会返回一个数,来指示受影响的行的数目。该数是被删除和被插入的行数的和。如果对于一个单行REPLACE该数为1,则一行被插入,同时没有行被删除。如果该数大于1,则在新行被插入前,有一个或多个旧行被删除。如果表包含多个唯一索引,并且新行复制了在不同的唯一索引中的不同旧行的值,则有可能是一个单一行替换了多个旧行。

受影响的行数可以容易地确定是否REPLACE只添加了一行,或者是否REPLACE也替换了其它行:检查该数是否为1(添加)或更大(替换)。

目前,您不能在一个子查询中,向一个表中更换,同时从同一个表中选择。


以下是所用算法的更详细的说明(该算法也用于LOAD DATA...REPLACE):

1. 尝试把新行插入到表中

2. 当因为对于主键或唯一关键字出现重复关键字错误而造成插入失败时:

a. 从表中删除含有重复关键字值的冲突行

b. 再次尝试把新行插入到表中

三种形式:

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, ...

PS:

mysql中常用的三种插入数据的语句:

insert into表示插入数据,数据库会检查主键,如果出现重复会报错;

replace into表示插入替换数据,需求表中有PrimaryKey,或者unique索引,如果数据库已经存在数据,则用新数据替换,如果没有数据效果则和insert into一样;

insert ignore表示,如果中已经存在相同的记录,则忽略当前新数据;

总结

今天文章就介绍到这了,有什么问题欢迎评论区留言。

原文  作者:CODETC 


学习C/C++编程知识,提升C/C++编程能力,欢迎关注UP一起来成长!

另外,UP在主页上传了一些学习C/C++编程的视频教程,有兴趣或者正在学习的小伙伴一定要去看一看哦!会对你有帮助的~

最后,如果你也想成为程序员,想要快速掌握编程,赶紧关注【 UP主页】加入学习企鹅圈子吧!

里面有资深专业软件开发工程师,在线解答你的所有疑惑~编程语言入门“so easy”

编程学习书籍:


编程学习视频:



投诉或建议

玻璃钢生产厂家欧式玻璃钢雕塑供应商佛像玻璃钢雕塑市场湖州公园玻璃钢雕塑生产厂家凯里玻璃钢雕塑制作哪家好玻璃钢动物雕塑牛仿真玻璃钢雕塑厂家工厂商场dp美陈雕塑深圳人物石氏玻璃钢雕塑阜新市玻璃钢雕塑定制吉林玻璃钢动物雕塑价格长沙大型玻璃钢雕塑沈阳学校玻璃钢雕塑厂家玻璃钢雕塑一平方用多少材料贵阳大型玻璃钢雕塑多少钱成套玻璃钢花盆图片大全 室外蚌埠商场开业美陈四川玻璃钢马雕塑艺术小品秋季商场美陈元素日照学校玻璃钢雕塑制作武汉人物玻璃钢雕塑定制西藏玻璃钢胸像雕塑芜湖玻璃钢雕塑批发价格滨江玻璃钢雕塑厂家上海玻璃钢牛头雕塑清远玻璃钢动物雕塑玻璃钢浮雕卡通雕塑韶关园林玻璃钢卡通雕塑迪庆商场美陈山西玻璃钢雕塑定制厂家深圳周年商场美陈报价香港通过《维护国家安全条例》两大学生合买彩票中奖一人不认账让美丽中国“从细节出发”19岁小伙救下5人后溺亡 多方发声单亲妈妈陷入热恋 14岁儿子报警汪小菲曝离婚始末遭遇山火的松茸之乡雅江山火三名扑火人员牺牲系谣言何赛飞追着代拍打萧美琴窜访捷克 外交部回应卫健委通报少年有偿捐血浆16次猝死手机成瘾是影响睡眠质量重要因素高校汽车撞人致3死16伤 司机系学生315晚会后胖东来又人满为患了小米汽车超级工厂正式揭幕中国拥有亿元资产的家庭达13.3万户周杰伦一审败诉网易男孩8年未见母亲被告知被遗忘许家印被限制高消费饲养员用铁锨驱打大熊猫被辞退男子被猫抓伤后确诊“猫抓病”特朗普无法缴纳4.54亿美元罚金倪萍分享减重40斤方法联合利华开始重组张家界的山上“长”满了韩国人?张立群任西安交通大学校长杨倩无缘巴黎奥运“重生之我在北大当嫡校长”黑马情侣提车了专访95后高颜值猪保姆考生莫言也上北大硕士复试名单了网友洛杉矶偶遇贾玲专家建议不必谈骨泥色变沉迷短剧的人就像掉进了杀猪盘奥巴马现身唐宁街 黑色着装引猜测七年后宇文玥被薅头发捞上岸事业单位女子向同事水杯投不明物质凯特王妃现身!外出购物视频曝光河南驻马店通报西平中学跳楼事件王树国卸任西安交大校长 师生送别恒大被罚41.75亿到底怎么缴男子被流浪猫绊倒 投喂者赔24万房客欠租失踪 房东直发愁西双版纳热带植物园回应蜉蝣大爆发钱人豪晒法院裁定实锤抄袭外国人感慨凌晨的中国很安全胖东来员工每周单休无小长假白宫:哈马斯三号人物被杀测试车高速逃费 小米:已补缴老人退休金被冒领16年 金额超20万

玻璃钢生产厂家 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化