猿问

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

我已经搜索到已经有一种方法可以避免重复错误

参考: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  |

+----+---------+-----------+------+

有没有办法批量这样做?或者批量添加数据的格式如何


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

有办法吗?


繁花不似锦
浏览 72回答 1
1回答

杨魅力

我建议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)冲突子句捕获唯一索引上的违规,并执行无操作更新。旁注:使用参数化查询将数据从应用程序传递到查询;转义输入不足以使您的查询安全。
随时随地看视频慕课网APP
我要回答