loader命令导出大批量数据维护SQL

一、背景

工作学习中,经常遇到几千,甚至上万条的数据维护任务,如果一条一条进行数据维护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';
相关推荐
高梦轩39 分钟前
MySQL高可用
android·运维·数据库
紫金修道3 小时前
【DeepAgent】概述
开发语言·数据库·python
孟章豪4 小时前
《SQL拼接 vs 参数化,为什么公司禁止拼接SQL?(附真实案例)》
服务器·数据库·sql
荒川之神4 小时前
ORACLE LEVEL函数练习
数据库·oracle
·云扬·4 小时前
【MySQL】实战:用pt-table-sync修复主从数据一致性问题
数据库·mysql·ffmpeg
swIn KWAL5 小时前
【MySQL】环境变量配置
数据库·mysql·adb
shark22222225 小时前
【JOIN】关键字在MySql中的详细使用
数据库·mysql
RATi GORI5 小时前
MySQL中的CASE WHEN语句:用法、示例与解析
android·数据库·mysql
坊钰5 小时前
Java 死锁问题及其解决方案
java·开发语言·数据库
onebound_noah5 小时前
【实战教程】如何通过API快速获取淘宝/天猫商品评论数据(含多语言Demo)
大数据·数据库