2013-02-10 47 views
12

Tôi có cấu trúc bảng sau:Cách nhanh nhất để cập nhật bảng MySQL nếu hàng tồn tại khác chèn. Hơn 2 phím không duy nhất

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`) 
) 

Hiện nay tôi kiểm tra & chèn/cập nhật với đoạn mã sau:

$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'"); 
} 

Là một cách nhanh nhất để cập nhật MySQL này bảng nếu hàng tồn tại khác chèn với hơn 2 phím không độc đáo?

Trả lời

17

chỉ cần sử dụng 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; 

nhưng trước khi bất cứ điều gì khác, bạn nên xác định một hạn chế UNIQUE trên các cột.

ALTER TABLE reports_adv ADD CONSTRAINT tb_uq UNIQUE (day, uid, siteid, cid) 
+0

Cảm ơn rất nhiều. Hoạt động tuyệt vời. – dracosu

+0

bạn được chào đón ': D' –

+0

Một câu hỏi khác. Khi tôi hiển thị dữ liệu tôi sử dụng vào WHERE ngày, uid, siteid và cid. Tôi nên thêm chỉ mục nào? – dracosu

Các vấn đề liên quan