mysql如果数据不存在,则插入新数据,否则更新的实现方法
作者:平凡简单 | 来源:互联网 | 2021-11-04 23:47
mysql如果数据不存在,则插入新数据,否则更新的实现方法
//如果不存在,则插入新数据 $sql = "INSERT INTO {$ecs->table(‘cat_lang')} (cat_id,lang_id,cat_name,keywords,cat_desc) VALUES({$cat_id},{$k},'{$val['cat_name']}','{$val['keywords']}','{$val['cat_desc']}') ON DUPLICATE KEY UPDATE cat_name='{$val['cat_name']}',cat_desc='{$val['cat_desc']}',keywords='{$val['cat_desc']}'"; 这里要注意的是:必须表主键唯一 。这里,这里我采用的是 分类id和语言id双主键机制。key为唯一键或者主键 (1) key存在则替换,不存在则插入 replace into t_test | CREATE TABLE `t_test` ( `ikey` int(11) NOT NULL default '0', `value` varchar(21) NOT NULL default '', `icount` int(11) NOT NULL default '0', PRIMARY KEY (`ikey`) ) ENGINE=MyISAM DEFAULT CHARSET=gbk | 对于这样一个表.当要记录ikey=1,value='a',icount=0时,由于不知道表里有没有ikey=1的项.我们可能会先select,然后看有没有结果,如果有,则使用update进行更新.如果没有,则使用insert进行插入. 不过在大并发量的数据操作时,可能有时一个有主键的select查询都要用上2s,如果对旧数据不关心,减少不必要的操作显得犹为重要. 使用replace一个语句可以完成上面两个语句的功能,其语法与insert差不多.如上面的操作可以写为replace into t_test set ikey=1,value='a',icount=0;则表中有ikey为1时,先删除旧数据.然后插入新数据.否则直接插入数据. (2) key存在则更新,不存在则插入 insert into .... on duplicate key update 对于需要根据原记录进行操作的.如表中icount字段用于计数,当没有记录时,插入的value为0,当有记录时,value需要更新为value+1,这时replace就不能完成这个功能.使用insert则可以,其基本语法是insert into ... on duplicate key update...,如上述语句为 insert into t_test set ikey=1,value='a',value2=1 on duplicate key update value2=value2+1; 如果表中有多个唯一索引,如对value字段加个unique key.这时表中有ikey和value两个唯一索引,replace会把所有与其唯一索引值相同的数据项删除,再插入新记录.如表中有两个记录 +------+-------+--------+ | ikey | value | icount | +------+-------+--------+ | 2 | a | 10 | | 1 | b | 40 | +------+-------+--------+ 则replace into t_test set ikey=1,value='a',icount=0;会把表中的两条记录都删除,然后插入新记录. 而insert into t_test set ikey=1,value='a',icount=0 on duplicate key update icount=icount+1则只更新一条记录.其效果相当于update t_test set icount=icount+1 where ikey=1 or value='a' limit 1;
推荐阅读
为什么这么设计(Why’sTHEDesign)是一系列关于计算机领域中程序设计决策的文章,我们在这个系列的每一篇文章中都会提出一个具体的问 ...
[详细]
蜡笔小新 2024-09-29 14:38:34
标签PostgreSQL,Linux,perf,性能诊断,stap,systemtap,strace,dtrace,dwarf,profiler,perf_events,probe ...
[详细]
蜡笔小新 2024-09-29 11:25:52
关键字:驰骋工作流程快速开发平台工作流程管理系统工作流引擎asp.net工作流引擎java工作流引擎.开发者表单拖拽式表单工作流系统流程数据加密md5数据保密流程数据防篡改软加密适 ...
[详细]
蜡笔小新 2024-09-28 18:39:01
MaxCompute是阿里EB级计算平台,经过十年磨砺,它成为阿里巴巴集团数据中台的计算核心和阿里云大数据的基础服务。去年MaxCompute做了哪些工作,这些工作背后的原因是什 ...
[详细]
蜡笔小新 2024-09-28 17:30:24
│037-where后面嵌套子查询.avi│038-from后面嵌套子查询.avi│039-select后面嵌套子查询.avi│040-union的用法.avi│041-limit ...
[详细]
蜡笔小新 2024-09-28 17:01:32
nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ...
[详细]
蜡笔小新 2024-09-28 16:52:03
前言SQLite(sql)是一款开源轻量级的数据库软件,不需要server,可以集成在其他软件中,非常适合嵌入式系统。Qt5以上版本可以直接使用SQLite(Qt自带驱动)。用法1 ...
[详细]
蜡笔小新 2024-09-28 16:07:59
MSSQL2012:如果列包含0,则在SQLSh ...
[详细]
蜡笔小新 2024-09-28 15:17:29
由于SQLServer2008比ReportBuilder2.0先发布,所以默认情况下,在SSRS2008中的报表管理器中单击“报表生成器”,打开的是ReportBuilder1.0版本 ...
[详细]
蜡笔小新 2024-09-28 13:27:24
问题说明最近看到Spring事务,在学习过程中遇到一个很苦恼问题搭建好Spring的启动环境后出现了一点小问题在启动时候却出现[java.lang.NullPointerExcep ...
[详细]
蜡笔小新 2024-09-28 11:25:55
在实际的软件项目的开发过程中,特别是在企业的应用系统集成(EAI)项目中广大开发人员经常遇到不同关系型数据库之间的数据移植问题。笔者根据自己在工作中的不同数据库数据移 ...
[详细]
蜡笔小新 2024-09-28 10:56:59
在关系数据库的对象关系映射中,表中的每行对应于类的一个实例,而每列的值对应于该实例的一个属性。于是,程序员可直接对Java对象进行操作 ...
[详细]
蜡笔小新 2024-09-28 10:31:22
Oracle日常管理用到的一些sql语句表空间及容量:selecttablespace_name,sum(bytes)102410241024fromdba_data ...
[详细]
蜡笔小新 2024-09-28 10:14:09
1.前言数据库应用,在许多软件系统中经常用到,是开发中大型系统不可缺少的辅助。但如果对数据库资源没有很好地管理(如:没有及时回收数据库的游 ...
[详细]
蜡笔小新 2024-09-27 20:22:03
第一部分:TSqlTop有两种用法1,限制查询结果集返回的行数或总行数的百分比。当将TOP与ORDERBY子句结合使用时,结果集限制为前N个已排序行;否则,以未定义的顺序返回前N个 ...
[详细]
蜡笔小新 2024-09-27 19:54:10