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';
相关推荐
m0_5613596718 小时前
掌握Python魔法方法(Magic Methods)
jvm·数据库·python
xxxmine18 小时前
redis学习
数据库·redis·学习
qq_54702617918 小时前
Redis 常见问题
数据库·redis·mybatis
APIshop18 小时前
Java 实战:调用 item_search_tmall 按关键词搜索天猫商品
java·开发语言·数据库
小陈phd19 小时前
混合知识库搭建:本地Docker部署Neo4j图数据库与Milvus向量库
数据库·docker·neo4j
2401_8384725119 小时前
使用Python进行图像识别:CNN卷积神经网络实战
jvm·数据库·python
知识即是力量ol19 小时前
基于 Redis 实现白名单,黑名单机制详解及应用场景
数据库·redis·缓存
zhihuaba19 小时前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
u01092727119 小时前
Python Web爬虫入门:使用Requests和BeautifulSoup
jvm·数据库·python
小光学长19 小时前
基于ssm的农业管理系统8y15w544(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库