【日常记录-MySQL】Shell自动登录MySQL并执行SQL脚本

Author:赵志乾
Date:2024-08-09
Declaration:All Right Reserved!!!

1. 简介

        在Shell脚本中自动登录MySQL并执行脚本是一个常见的自动化任务,尤其是在数据备份、报表生成或批量数据处理时非常有用。要实现这一点,可以使用mysql命令行工具配合-u、-p、-h(若为本地可以省略)以及数据库名等选项,但直接在脚本中硬编码密码可能存在安全风险。一种更安全的方法是使用配置文件或环境变量来管理敏感信息。

2. 示例

#!/bin/bash  
  
USER="your_username"  
HOST="localhost"  
DATABASE="your_database"  
  
# SQL脚本文件路径  
SQL_SCRIPT="/path/to/your_script.sql"  
  
# 使用配置文件(.my.cnf),但这需要谨慎管理文件权限  
# 在用户的主目录下创建或编.my.cnf文件,并添加以下内容:  
# [client]  
# user=your_username  
# password=your_password  
# host=localhost  
  
# 接下来,我们可以使用mysql命令如下(无需-p参数):  
mysql -u"$USER" -h"$HOST" "$DATABASE" < "$SQL_SCRIPT"  
   
  
echo "SQL script executed successfully."

3. 注意事项

  • 避免在脚本中硬编码密码:使用环境变量或MySQL的配置文件来管理敏感信息;
  • 权限管理:确保Shell脚本和配置文件的安全,只有授权用户才能访问;
  • 日志管理:注意任何可能记录密码或敏感信息的日志文件,确保它们不被未授权访问;

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我叫白小猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值