我已经搜索到已经有一种方法可以避免重复错误参考: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)
冲突子句捕获唯一索引上的违规,并执行无操作更新。
旁注:使用参数化查询将数据从应用程序传递到查询;转义输入不足以使您的查询安全。
- 1 回答
- 0 关注
- 71 浏览
添加回答
举报
0/150
提交
取消