一、背景
工作学习中,经常遇到几千,甚至上万条的数据维护任务,如果一条一条进行数据维护SQL的编写,将是巨大的工作量。本文将分享2个小技巧,减小准备大批量数据维护SQL的工作量。
方案 1: loader 支持直接输出文本
loader 执行纯 SELECT,然后用 shell 重定向:
java
loader \
-type="out" \
-db-conn-info="196.0.0.1:8002" \
-sql="SELECT CONCAT('update table set field1=''小时'',field2=''虽然'' where field3=''', field3, ''' and field4=''', field4, ''';') FROM table1 WHERE field3='12345';" \
-user="admin" \
-password="123456" \
> /data/path/file.sql 2>log/table1.log &
MySQL 中字符串用两个单引号 '' 转义,而不是反斜杠。
方案 2:当 loader 直接连 MySQL用 INTO OUTFILE
java
SELECT CONCAT('update `table` set field1=\'小时\',field2=\'虽然\' where field3=\'', field3, '\' and field4=\'', field4, '\';')
FROM table1
WHERE field3 = '12345'
INTO OUTFILE '/data/export/file.sql'
FIELDS TERMINATED BY ''
LINES TERMINATED BY '\n';