SQL执行后台脚本

SQL进程中断实验

我们操作数据库时,经常遇到数据导入等特别耗时的SQL操作,而关闭MySQL客户端或SSH终端,就会立马关闭SQL会话,导致SQL执行中断,如下实验:

  1. 在第一个SSH终端执行
shell 复制代码
# 进入Mysql客户端,模拟一个sleep(30)秒的耗时操作:
$ mysql -uroot
mysql> select sleep(30);
  1. 打开第二个SSH终端。查看Msql进程
shell 复制代码
$ mysql -uroot -e "SHOW PROCESSLIST";

+-----+-----------------+-----------+------+---------+--------+------------------------+------------------+
| Id  | User            | Host      | db   | Command | Time   | State                  | Info             |
+-----+-----------------+-----------+------+---------+--------+------------------------+------------------+
|   5 | event_scheduler | localhost | NULL | Daemon  | 230197 | Waiting on empty queue | NULL             |
| 180 | root            | localhost | NULL | Query   |      8 | User sleep             | select sleep(30) |
| 181 | root            | localhost | NULL | Query   |      0 | init                   | SHOW PROCESSLIST |
+-----+-----------------+-----------+------+---------+--------+------------------------+------------------+
  1. 关闭第一个SSH终端,再次执行第二步(查看Msql进程)。 发现sleep进程已关闭。

守护进程执行SQL

可以借助于nohup,在后台执行sql命令/脚本,格式如下:

sql 复制代码
nohup mysql -u用户名 -p密码 -e "YOUR_SQL" &
nohup mysql -u用户名 -p密码 < script.sql &

终端直接执行SQL语句

shell 复制代码
$ mysql -uroot -e "show databases";
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+

$ mysql -uroot -e "select @@version";
+-----------+
| @@version |
+-----------+
| 8.3.0     |
+-----------+

nohup执行SQL

shell 复制代码
# 模拟一个耗时的SQL操作(sleep 10秒),然后将执行结果写入文件
$ nohup mysql -uroot -e "select sleep(10);select now() as complected;select 'SQL执行完毕' as result;" > nohup.txt 2>&1 &

# 验证结果
$ cat nohup.txt
nohup: ignoring input
sleep(10)
0
complected
2024-03-04 03:27:25
result
SQL执行完毕

nohup执行脚本

shell 复制代码
nohup mysql -h192.168.10.11 -uroot -p123456 < db.sql > nohup.txt 2>&1 &
相关推荐
wbs_scy12 小时前
MySQL 多表连接查询实战:内连接 + 外连接
数据库·mysql
cfm_291413 小时前
MySQL8.0 核心新特性详解(架构/性能/SQL/索引/安全全覆盖)
sql·安全·架构
largecode13 小时前
座机号码认证如何操作?申请热线实名名片,树立统一官方客服形象
linux·sql·华为·c#·.net·wpf·harmonyos
BD_Marathon13 小时前
SQL学习指南——事务
数据库·sql·oracle
IT龟苓膏14 小时前
MySQL 表设计与 SQL 优化:从字段类型、主键设计到深分页优化一篇讲清
数据库·sql·mysql
2601_9520477915 小时前
金蝶云星空与管易云系统对接方案
mysql
这个DBA有点耶15 小时前
数据库管理工具+开发工具的融合:AI如何重塑DBA工作流?
开发语言·数据库·人工智能·sql·云计算·dba
数据库小学妹16 小时前
异构数据库同步实战:如何打通Oracle/MySQL/SQL Server的数据孤岛
数据库·mysql·oracle
数据库知识分享者小北16 小时前
安全可靠数据库选型之阿里云 PolarDB MySQL 版V2.0
数据库·mysql·阿里云·国产数据库·polardb·安全可靠数据库·polardb-m
热爱Liunx的丘丘人17 小时前
Docker Compose 实现 Nginx 与 MySQL 多容器服务编排
mysql·nginx·docker