Php 如果存在行,更新MySQL表的最快方法是插入。超过2个非唯一密钥
我有以下表格结构:Php 如果存在行,更新MySQL表的最快方法是插入。超过2个非唯一密钥,php,mysql,sql,sql-update,sql-insert,Php,Mysql,Sql,Sql Update,Sql Insert,我有以下表格结构: 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表的最快方法?或者使用超过2个非唯一键插入?只需在重复键更新时使用
insert…
INSERT INTO reports_adv (day, uid, siteid, cid, visits)
VALUES ('$day', '$uid', '$sid', '$cid', 1)
ON DUPLICATE KEY UPDATE visits=visits+1;
UNIQUE
约束
ALTER TABLE reports_adv ADD CONSTRAINT tb_uq UNIQUE (day, uid, siteid, cid)
非常感谢。很好,还有一个问题。当我显示我在WHERE day、uid、siteid和cid上使用的数据时。我应该添加哪些索引?没有,因为此语句
UNIQUE(day、uid、siteid、cid)
隐式地为您添加索引。太好了。再次感谢你。你救了我:)