亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

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

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

PHP
繁花不似錦 2022-10-28 15:42:37
我已經搜索到已經有一種方法可以避免重復錯誤參考:MySQL:如果表中不存在則插入記錄INSERT INTO table_listnames (name, address, tele)SELECT * FROM (SELECT 'Unknown' AS name, 'Unknown' AS address, '022' AS tele) AS tmpWHERE 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: 0SELECT * FROM `table_listnames`;+----+---------+-----------+------+| id | name    | address   | tele |+----+---------+-----------+------+|  1 | Rupert  | Somewhere | 022  ||  2 | John    | Doe       | 022  ||  3 | Unknown | Unknown   | 022  |+----+---------+-----------+------+有沒有辦法批量這樣做?或者批量添加數據的格式如何ref:通過 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));有辦法嗎?
查看完整描述

1 回答

?
楊魅力

TA貢獻1811條經驗 獲得超6個贊

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


為此,您需要對 colum 進行唯一(或主鍵)約束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)

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


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


查看完整回答
反對 回復 2022-10-28
  • 1 回答
  • 0 關注
  • 96 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號