问题描述
今天在使用tp3.2插入数据的时候,为了避免插入相同的数据(所谓相同的数据,其主键相同或者是唯一索引的字段相同),我创建的索引如下图,主键索引为自增字段,不可能出现重复,即唯一索引可能会出现重复,我希望的是uid,year,mounth,day 这三个字段出现相同的话,就更新当前记录。
问题解决办法
在之前面对这样的问题的时候,我们知道,mysql提供了on duplicate key update或者replace into来解决。
使用on duplicate key update
插入数据之前,表中就一条记录,如下图
sql语句如下,当插入记录时候,与表中已有记录相同,则更新改条记录,否则插入记录。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
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
代码如下:
先执行如下代码插入一条数据
1
2
3
4
5
6
7
8
9
|
replace into `work_log` (
`uid`,
`year`,
`mounth`,
`day`,
`status`
)
values
(1, 2016, 6, 2, 1)
|
效果如下图
再次执行如下代码,就会更新上面插入的代码
1
2
3
4
5
6
7
8
9
|
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方法中第三个参数。
以上这篇完美解决thinkphp3.2中插入相同数据的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持快网idc。
相关文章
- 个人服务器网站搭建:如何选择适合自己的建站程序或框架? 2025-06-10
- 64M VPS建站:能否支持高流量网站运行? 2025-06-10
- 64M VPS建站:怎样选择合适的域名和SSL证书? 2025-06-10
- 64M VPS建站:怎样优化以提高网站加载速度? 2025-06-10
- 64M VPS建站:是否适合初学者操作和管理? 2025-06-10
- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
- 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
- 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
- 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
- 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
快网idc优惠网
QQ交流群
-
2025-06-04 25
-
2025-05-25 71
-
2025-05-25 14
-
2025-05-27 23
-
CentOS 6.4安装配置LNMP服务器(Nginx+PHP+MySQL)
2025-05-25 67