Thinkphp3.2中解决插入相同数据的问题
2016-06-03 15:16
561 查看
问题描述
今天在使用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方法中第三个参数。
相关文章推荐
- zend studio 用xdebug在chrome上远程调试
- 大学生进阶为PHP工程师的艰辛过程
- Yii 2 初体验
- 【转】一名大学生的PHP进阶之路
- PHP 流程
- Yii2 用户登录
- PHP 权限
- PHP 三元运算符省略写法
- 在自己的框架中引用 PHPExcel
- PHP_$_SERVER_说明详解
- utf-8+DOM 中的 php
- YII1.1升级到2.0笔记
- 运用Thinkphp搭建简单留言板(附源码)-(下)
- PHP学习笔记之php文件操作
- php中字符操作笔记
- ABAP CL_DEMO_OUTPUT类
- Thinkphp 图像处理GD库结合jcrop插件总结
- Thinkphp ajax异步提交的方法总结
- phpdesigner 的配置
- PHP文件操作