加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – 如果行存在else insert,则可以更新MySQL表的最快方法.超

发布时间:2020-12-13 14:02:36 所属栏目:PHP教程 来源:网络整理
导读:我有以下表格结构: CREATE TABLE IF NOT EXISTS `reports` ( `id` int(11) NOT NULL AUTO_INCREMENT,`day` int(11) NOT NULL,`uid` int(11) NOT NULL,`siteid` int(11) NOT NULL,`cid` int(3) NOT NULL,`visits` int(11) NOT NULL,PRIMARY KEY (`id`) ) 目
我有以下表格结构:
CREATE TABLE IF NOT EXISTS `reports` (
  `id` int(11) NOT NULL AUTO_INCREMENT,`day` int(11) NOT NULL,`uid` int(11) NOT NULL,`siteid` int(11) NOT NULL,`cid` int(3) NOT NULL,`visits` int(11) NOT NULL,PRIMARY KEY (`id`)
 )

目前我检查使用以下代码段插入/更新:

$checkq = mysql_query("SELECT count(*) as rowexist FROM reports WHERE day='$day' AND uid='$uid' AND siteid='$sid' AND cid='$cid'") or die(mysql_error()); 
$checkr = mysql_fetch_array($checkq);

if ($checkr['rowexist'] > 0) {
 mysql_query("UPDATE reports_adv SET visits=visits+1 WHERE  day='$day' AND uid='$uid' AND siteid='$sid' AND cid='$cid'"); 
} else {
 mysql_query("INSERT INTO reports_adv SET day='$day',uid='$uid',siteid='$sid',cid='$cid',visits='1'");
}

是否更新此MySQL表的最快方法是否存在else else插入超过2个非唯一的键?

只需使用INSERT … ON DUPLICATE KEY UPDATE
INSERT INTO reports_adv (day,uid,siteid,cid,visits) 
VALUES ('$day','$uid','$sid','$cid',1)
ON DUPLICATE KEY UPDATE visits=visits+1;

> INSERT … ON DUPLICATE KEY UPDATE Syntax

但在其他任何事情之前,您应该在列上定义一个UNIQUE约束.

ALTER TABLE reports_adv  ADD CONSTRAINT tb_uq UNIQUE (day,cid)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读