2012-04-10 58 views
16

Tôi có một số mã trông như thế này. Ngoài ra còn có một trường tự động trong bảng mà tôi phải giữ lại (nó được sử dụng trong các bảng khác). Tôi muốn đơn giản hóa và tối ưu hóa mã này.MySql: nếu giá trị tồn tại UPDATE khác INSERT

$query ="SELECT * FROM models WHERE col1 = 'foo'"; 
$testResult = mysql_query($query) or die('Error, query failed');  

if(mysql_fetch_array($testResult) == NULL){ 
    //insert... 
    $query ="INSERT INTO models (col1, col2, col3) 
    VALUES ('foo', 'bar', 'alph')"; 
    $result = mysql_query($query) or die('Error, query failed'); 
}else{ 
    //update... 
    $query = "UPDATE models 
     SET col1='foo', col2='bar', col3='alph' 
     WHERE col1='foo' AND col2='bar'"; 
     $result = mysql_query($query) or die('Error, query failed');   
} 

Chỉnh sửa: Id khóa chính là trường được tăng tự động. Tôi không bao giờ muốn thay đổi điều này. Tuy nhiên, khi một trường khác được sao chép, đây là khi tôi muốn cập nhật bản ghi đó.

+4

Check-out: [INSERT ... ON DUPLICATE KEY CẬP NHẬT Cú pháp] (http://dev.mysql.com/doc/refman/5.0/en/insert-on-duplicate.html) – Josh

+0

gì đã làm bạn có nghĩa là bởi 'một lĩnh vực autoincrement' – hjpotter92

+0

Câu hỏi này có thể hữu ích ... [Làm thế nào để chèn dữ liệu vào MySQL có tự động tăng khóa chính?] (https://stackoverflow.com/questions/8753371/how-to-insert- data-to-mysql-have-auto-incremented-primary-key) – blackandorangecat

Trả lời

29

Làm thế nào về REPLACE INTO:

REPLACE INTO models 
(col1, col2, col3) 
VALUES 
('foo', 'bar', 'alpha') 

Giả sử col1 là khóa chính của bạn, nếu một hàng có giá trị 'foo' đã tồn tại, nó sẽ cập nhật hai cột còn lại. Nếu không, nó sẽ chèn một hàng mới.

+0

sự cố với 'replace' là nó giả định mục nhập tồn tại. Nhưng việc sử dụng muốn chèn hoặc cập nhật - cả hai. – kasavbere

+1

Nó được đặt tên kém. Nó không cho rằng mục nhập tồn tại. Từ các tài liệu MySQL: "REPLACE hoạt động chính xác như INSERT, ngoại trừ nếu một hàng cũ trong bảng có cùng giá trị như một hàng mới cho một PRIMARY KEY hoặc một chỉ mục UNIQUE, hàng cũ sẽ bị xóa trước khi hàng mới được chèn vào. " – bobwienholt

+0

Tôi không biết điều đó. hãy bình chọn cho bạn - Tôi đã học được điều gì đó mới mẻ ngay hôm nay! – kasavbere

6

bạn có thể thử sử dụng "INSERT ... ON UPDATE KEY DUPLICATE" cú pháp

http://dev.mysql.com/doc/refman/5.0/en/insert-on-duplicate.html

If you specify ON DUPLICATE KEY UPDATE, and a row is inserted that would cause a duplicate value in a UNIQUE index or PRIMARY KEY, an UPDATE of the old row is performed. For example, if column a is declared as UNIQUE and contains the value 1, the following two statements have identical effect: 

INSERT INTO table (a,b,c) VALUES (1,2,3) 
    ON DUPLICATE KEY UPDATE c=c+1; 

UPDATE table SET c=c+1 WHERE a=1; 
The ON DUPLICATE KEY UPDATE clause can contain multiple column assignments, separated by commas. 

With ON DUPLICATE KEY UPDATE, the affected-rows value per row is 1 if the row is inserted as a new row and 2 if an existing row is updated. 

If column b is also unique, the INSERT is equivalent to this UPDATE statement instead: 

UPDATE table SET c=c+1 WHERE a=1 OR b=2 LIMIT 1; 
If a=1 OR b=2 matches several rows, only one row is updated. In general, you should try to avoid using an ON DUPLICATE KEY clause on tables with multiple unique indexes. 

You can use the VALUES(col_name) function in the UPDATE clause to refer to column values from the INSERT portion of the INSERT ... UPDATE statement. In other words, VALUES(col_name) in the UPDATE clause refers to the value of col_name that would be inserted, had no duplicate-key conflict occurred. This function is especially useful in multiple-row inserts. The VALUES() function is meaningful only in INSERT ... UPDATE statements and returns NULL otherwise. Example: 

INSERT INTO table (a,b,c) VALUES (1,2,3),(4,5,6) 
    ON DUPLICATE KEY UPDATE c=VALUES(a)+VALUES(b); 
That statement is identical to the following two statements: 

INSERT INTO table (a,b,c) VALUES (1,2,3) 
    ON DUPLICATE KEY UPDATE c=3; 
INSERT INTO table (a,b,c) VALUES (4,5,6) 
    ON DUPLICATE KEY UPDATE c=9; 
If a table contains an AUTO_INCREMENT column and INSERT ... UPDATE inserts a row, the LAST_INSERT_ID() function returns the AUTO_INCREMENT value. If the statement updates a row instead, LAST_INSERT_ID() is not meaningful. However, you can work around this by using LAST_INSERT_ID(expr). Suppose that id is the AUTO_INCREMENT column. To make LAST_INSERT_ID() meaningful for updates, insert rows as follows: 

INSERT INTO table (a,b,c) VALUES (1,2,3) 
    ON DUPLICATE KEY UPDATE id=LAST_INSERT_ID(id), c=3; 
The DELAYED option is ignored when you use ON DUPLICATE KEY UPDATE. 
6

Bạn chỉ cần cập nhật col3 trên bản sao. Đây chính xác là những gì bạn đang yêu cầu.

INSERT INTO models (col1, col2, col3) 
VALUES ('foo', 'bar', 'alpha') 
ON DUPLICATE KEY UPDATE col3='alpha'; 
Các vấn đề liên quan