通过shell脚本对mysql的增删改查及my.cnf的配置
2021-08-02 04:10
1316 查看
shell操作mysql
1.获取mysql默认密码
新安装的mysql,密码是默认密码
#!/bin/bash # STRING:获取mysql默认密码的一段字符串 # 例如:A temporary password is generated for root@localhost: xxxxxx # PASSWORD:将获取到的STRING进行截取,获取localhost:右边的默认密码 # shellcheck disable=SC2006 STRING=`grep "temporary password" /var/log/mysqld.log` PASSWORD=${STRING#*localhost: }
若已经修改了密码的
#!/bin/bash # shellcheck disable=SC2006 PASSWORD="你的密码"
2.修改my.cnf文件
原因:在mysq5.6还是5.7以上,使用如下的shell脚本进行连接,会提示在命令行输入密码不安全。
mysql -u root -pPASSWORD -e "xxxxxx"
解决方法:使用sed命令在my.cnf文件中添加如下字段
[client] user=root password=xxxxxx
shell脚本:
# 我的my.cnf文件在/etc/my.cnf下,不相同的可以自己去找找 # sed -i '第几行 添加的内容' 指定的文件 sed -i '1i [client]' /etc/my.cnf sed -i '2i user=root' /etc/my.cnf sed -i '3i password=xxxxxx' /etc/my.cnf
3.shell创建mysql数据库
# SQL语句 DATABASE_SQL="CREATE DATABASE IF NOT EXISTS test" # mysql -u 用户名 -e "sql语句" # 因为在my.cnf中配置了密码,所以不用写密码了 mysql -u root -e "${DATABASE_SQL}"
4.shell创建mysql表
# sql语句 TEST_SQL="CREATE TABLE IF NOT EXISTS test ( id varchar(20) NOT NULL, text varchar(20) NOT NULL) ENGINE=InnoDB" # mysql -u 用户名 -D "数据库名" -e "sql语句" mysql -u root -D "test" -e "${TEST_SQL}"
5.shell添加数据
# sql语句 INSERT_SQL="insert into test values ('123', 'test')" mysql -u root -D "test" -e "${INSERT_SQL}"
6.shell删除数据
DELETE_SQL="delete from test where id='123'" mysql -u root -D "test" -e "${DELETE_SQL}"
7.shell修改数据
UPDATE_SQL="update test set text='你好' where id='123'" mysql -u root -D "test" -e "${UPDATE_SQL}"
8.shell查找数据
SELECT_SQL="select id, text from test where id='123'" mysql -u root -D "test" -e "${SELECT_SQL}"
9.shell修改数据库密码
# mysql5.7之前 SQL="update mysql set password=password("新密码") where user='root'" # mysql5.7及以后 SQL="update mysql set authentication_string=password("新密码") where user='root'" # flush privileges:刷新 mysql -u root -D "mysql" -e "${SQL};flush privileges"
到此这篇关于通过shell脚本对mysql的增删改查及my.cnf的配置的文章就介绍到这了,更多相关shell脚本mysql增删改查内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章:相关文章推荐
- Centos 通过yum默认安装mysql,my.cnf的常用配置
- 关于ubuntu12.04.1上修改MySQL的my.cnf参数配置文件问题
- Linux下Shell脚本部署Mysql服务的配置文件
- MYSQL中MY.CNF配置文件及参数介绍
- mysql配置文件my.cnf详解
- mysql的主从配置+shell脚本的检测和邮箱报警(版本centos7)
- linux mysql 双主复制配置文件my.cnf
- mysql my.cnf 配置建议
- 参考《MySQL管理之道》单机下的mysql的my.cnf配置
- mysql配置文件my.cnf基本配置与参数调优
- 用一行脚本美化/etc/my.cnf配置文件
- MySQL 5.6 my.cnf 配置
- MariaDB(Mysql分支)my.cnf配置文件中文注释版
- MySQL配置文件my.cnf优化详解,注意MySQL 5.5版本和其他前版本有些不一样的参数
- MYSQL--my.cnf配置中文详解
- linux下mysql配置文件my.cnf详解
- mysql配置文件my.cnf优化实例
- ubuntu mysql 配置文件my.cnf 更改tmp路径
- 再谈mysql的配置文件my.ini or my.cnf (之一)
- linux下mysql配置文件my.cnf详解【转】