mysqlupdate语句批量修改
时间: 2023-11-07 10:06:39 浏览: 128
mysql 批量更新有以下几种方法:
1. 使用 `REPLACE INTO` 批量更新:使用该语句可以将指定的数据插入到表中,如果主键冲突则进行替换更新。示例:`REPLACE INTO test_tbl(id, dr) VALUES (1, '2'), (2, '3'), ...(x, 'y');`
2. 使用 `INSERT INTO ... ON DUPLICATE KEY UPDATE` 批量更新:使用该语句可以将指定的数据插入到表中,如果主键冲突则进行更新操作。示例:`INSERT INTO test_tbl(id, dr) VALUES (1, '2'), (2, '3'), ...(x, 'y') ON DUPLICATE KEY UPDATE dr = VALUES(dr);`
3. 创建临时表,先更新临时表,然后从临时表中更新目标表:该方法需要用户有创建临时表的权限。示例:先创建临时表 `CREATE TEMPORARY TABLE tmp(id INT(4) PRIMARY KEY, dr VARCHAR(50));`,然后将数据插入临时表 `INSERT INTO tmp VALUES (0, 'gone'), (1, 'xx'), ...(m, 'yy');`,最后使用 `UPDATE` 语句从临时表中更新目标表 `UPDATE test_tbl, tmp SET test_tbl.dr = tmp.dr WHERE test_tbl.id = tmp.id;`
4. 使用MySQL自带的语句进行批量更新:这种方法可以根据具体需求使用MySQL提供的语句来实现批量更新。
需要注意的是,如果一条条去更新记录,效率会相当慢,并且容易造成阻塞。因此,使用批量更新语句可以提高性能和效率。
阅读全文