簡體   English   中英

PHP Mysql 插入批處理如果不存在

[英]PHP Mysql Insert Batch if not exist

我已經搜索過,已經有一種插入方法可以避免重復錯誤

參考: MySQL:如果表中不存在則插入記錄

INSERT INTO table_listnames (name, address, tele)
SELECT * FROM (SELECT 'Unknown' AS name, 'Unknown' AS address, '022' AS tele) AS tmp
WHERE NOT EXISTS (
    SELECT name FROM table_listnames WHERE name = 'Unknown'
) LIMIT 1;

Query OK, 1 row affected (0.00 sec)
Records: 1  Duplicates: 0  Warnings: 0

SELECT * FROM `table_listnames`;

+----+---------+-----------+------+
| id | name    | address   | tele |
+----+---------+-----------+------+
|  1 | Rupert  | Somewhere | 022  |
|  2 | John    | Doe       | 022  |
|  3 | Unknown | Unknown   | 022  |
+----+---------+-----------+------+

有沒有辦法批量執行此操作? 或者批量添加數據的格式如何

參考: 通過 php 數組將多行插入到 mysql 中

計划整合這個

$sql = array(); 
foreach( $data as $row ) {
    $sql[] = '("'.mysql_real_escape_string($row['text']).'", '.$row['category_id'].')';
}
mysql_query('INSERT INTO table (text, category) VALUES '.implode(',', $sql));

有辦法嗎?

我建議為此使用ON DUPLICATE KEY語法。 這將簡化查詢,並允許使用VALUES()語句,這對於從應用程序傳遞參數非常方便。

為此,您需要對列name設置唯一(或主鍵)約束。 如果它不存在,則創建它:

create unique index idx_table_listnames on table_listnames(name);

然后,你可以這樣做:

insert into table_listnames(name, address, tele)
values('Unknown', 'Unknown', '022')
on duplicate key update name = values(name)

沖突子句捕獲唯一索引上的違規,並執行無操作更新。

旁注:使用參數化查詢將數據從應用程序傳遞到查詢; 轉義輸入不足以使您的查詢安全。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM