Thinkphp3.2中解决插入相同数据的问题
来源:互联网 发布:apache solr 快速入门 编辑:程序博客网 时间:2024/06/03 21:54
问题描述
今天在使用TP3.2插入数据的时候,为了避免插入相同的数据(所谓相同的数据,其主键相同或者是唯一索引的字段相同),我创建的索引如下图,主键索引为自增字段,不可能出现重复,即唯一索引可能会出现重复,我希望的是uid
,year
,mounth
,day
这三个字段出现相同的话,就更新当前记录。
问题解决办法
在之前面对这样的问题的时候,我们知道,MySQL提供了ON DUPLICATE KEY UPDATE
或者REPLACE INTO
来解决。
使用ON DUPLICATE KEY UPDATE
插入数据之前,表中就一条记录,如下图
SQL语句如下,当插入记录时候,与表中已有记录相同,则更新改条记录,否则插入记录。
INSERT INTO `work_log` ( `uid`, `year`, `mounth`, `day`, `status`) VALUES (1, 2016, 6, 3, 1) ON DUPLICATE KEY UPDATE `status` = VALUES (`status`), `updated_ts` = NOW();
结果如下图
使用REPLACE INTO
代码如下:
先执行如下代码插入一条数据
REPLACE INTO `work_log` ( `uid`, `year`, `mounth`, `day`, `status`) VALUES (1, 2016, 6, 2, 1)
效果如下图
再次执行如下代码,就会更新上面插入的代码
REPLACE INTO `work_log` ( `uid`, `year`, `mounth`, `day`, `status`) VALUES (1, 2016, 6, 2, 5)
效果如下图
ON DUPLICATE KEY UPDATE
与REPLACE INTO
区别
当出现相同的值时候,ON DUPLICATE KEY UPDATE
是更新已经存在的记录,REPLACE INTO
是删除之前的记录,然后插入新的记录。
Thinkphp3.2中解决办法
在Thinkphp3.2中,通过add()函数的第三个参数来处理插入相同数据的问题。
Model.class.php中add()方法,调用了Db.class.php中insert中方法,在insert方法中,我们可以看到有如下代码:
其中$replace
正好是add方法中第三个参数。
1 0
- Thinkphp3.2中解决插入相同数据的问题
- mysql中插入数据,跳过unique字段相同的数据
- ThinkPHP3.2中parseXmlAttr的问题
- oracle中插入数据出现乱码问题的解决
- 解决mysql数据库中无法插入中文数据的问题
- 批量插入数据解决我的问题 3G数据插入
- 解决MySQL无法插入数据的问题!
- 完美解决thinkphp3的mysql连接问题
- ThinkPHP3.2使用addAll()方法批量插入数据
- oracle中从一个表中插入数据到另一个相同表结构的表中
- insert中加入where条件判断,解决插入重复数据的问题
- linux中解决oracle数据库插入中文数据乱码的问题
- 如何解决数据库中插入数据中文乱码问题(简单并完美解决数据库中插入数据中文乱码问题)
- MySql 相同记录插入与否的问题。
- 在ThinkPhp3.2 中 href 问题
- java中map插入相同的key
- sql 把a表的数据插入b表中,where某一个字段相同
- 解决学生信息管理系统之List列表中重复添加相同数据问题。
- Zookeeper可视化工具。 ZK 安装 node-zk-browser。2015.10.22亲测可用
- Android快速findViewById
- 排序:直接插入排序
- jmeter之关联
- c++ vector, set, map的用法总结
- Thinkphp3.2中解决插入相同数据的问题
- 小成本营销,从餐厅的邮件说起
- LeetCode-136:Single Number
- 关于在阿里云服务器或者腾讯云服务器(或者两者混合)搭建Hadoop 2.0 HA的注意事项
- freemarker,*.ftl文件在eclipse中正确的打开方式
- EXC_BAD_ACCESS in UIWebView
- PHP初学者教程之必备6个技能
- 信息安全——对称算法与非对称算法
- RHEL7配置双网卡冗余