shell脚本中执行mysql sql脚本文件并传递参数
1 shell 文件内容替换
sed是一个很好的文件处理工具,本身是一个管道命令,主要是以行为单位进行处理,可以将数据行进行替换、删除、新增、选取等特定工作,下面先了解一下sed的用法。
调用sed命令有两种形式:
sed [options] 'command' file(s) sed [options] -f scriptfile file(s)
常用选项:
-n∶使用安静(silent)模式。在一般sed 的用法中,所有来自 STDIN的资料一般都会被列出到萤幕上。但如果加上 -n 参数后,则只有经过sed特殊处理的那一行(或者动作)才会被列出来。
-e∶直接在指令列模式上进行 sed 的动作编辑;
-f∶直接将 sed 的动作写在一个档案内, -f filename 则可以执行 filename 内的sed动作;
-r∶sed 的动作支援的是延伸型正规表示法的语法。(预设是基础正规表示法语法)
-i∶直接修改读取的档案内容,而不是由萤幕输出。
常用命令:
a∶新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~
c∶取代, c 的后面可以接字串,这些字串可以取代n1,n2 之间的行!
d∶删除,因为是删除啊,所以 d后面通常不接任何咚咚;
i∶插入, i的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);
p∶列印,亦即将某个选择的资料印出。通常 p 会与参数 sed-n 一起运作~
s∶取代,可以直接进行取代的工作哩!通常这个 s的动作可以搭配正规表示法!例如 1,20s/old/new/g 就是啦!
举例:
#删除第一行
sed '1d' abc.file #删除最后一行
sed '$d' abc.file #删除第一行到第二行
sed '1,2d' abc.file #删除第二行到最后一行
sed '2,$d' abc.file #显示第一行
sed -n '1p' abc.file #显示最后一行
sed -n '$p' abc.file #显示第一行到第二行
sed -n '1,2p' abc.file #显示第二行到最后一行
sed -n '2,$p' abc.file #查询包括关键字ruby所在所有行
sed -n '/ruby/p' abc.file #查询包括关键字$所在所有行,使用反斜线\屏蔽特殊含义
sed -n '/\$/p' abc.file #第一行后增加字符串"drink tea"
sed '1a drink tea' abc.file && cat abc.file Hello!
drink tea
ruby is me,welcome to my blog.
end #第一行到第三行后增加字符串"drink tea"
sed '1,3a drink tea' abc.file && cat abc.file
Hello!
drink tea
ruby is me,welcome to my blog.
drink tea
end
drink tea #第一行后增加多行,使用换行符\n
sed '1a drink tea\nor coffee' abc.file && cat abc.file
Hello!
drink tea
or coffee
ruby is me,welcome to my blog.
end #第一行代替为Hi
sed '1c Hi' abc.file
Hi
ruby is me,welcome to my blog.
end #第一行到第二行代替为Hi
sed '1,2c Hi' abc.file
Hi
end #替换一行中的某部分格式:sed 's/要替换的字符串/新的字符串/g' (要替换的字符串可以用正则表达式)
#替换ruby为bird
sed -n '/ruby/p' abc.file | sed 's/ruby/bird/g' #删除ruby
sed -n '/ruby/p' abc.file | sed 's/ruby//g' #将当前目录下包含ruby串的文件中,ruby字符串替换为java
sed -i "s/ruby/java/g" `grep "ruby" -rl ./` #将某个文件中的jack字符串替换为tom
sed -i "s/ruby/java/g" abc.file #在文件abc.file中最后一行直接输入"bye"
sed -i '$a bye' abc.file && cat abc.file
Hello!
ruby is me,welcome to my blog.
end
bye
2. shell 执行mysql文件
2.1 语法
mysql -h host -P port_number -u username -p password <file_to_execute.sql
2.2 shell执行sql文件,并传参
给mysql的.sql的脚本文件传递参数,只能利用本文1部分介绍的sed在调用mysql执行命令前,把sql文件中的变量值替换掉,然后调用mysql命令执行sql脚本文件。
举例:
准备mysql数据库
create database if not exists test;
use test;
drop table if exists demo_table;
create table demo_table(a varchar(20),age int);
insertstmt.sql
insert into test.demo_table values(@name,@age);
exit
该脚本文件往mysql数据库test中的表demo_table中插入一条记录,这条记录的两个值都是变量,需要外面传递进来
execute.sh
#!/bin/sh
NAME="lenmom"
AGE= # set parameters as sql variables && add them to the first line of t.sql
sed -i "1 i\ set @name='$NAME';" insertstmt.sql
sed -i "1 i\ set @age=$AGE;" insertstmt.sql # execute sql script
mysql -u root < insertstmt.sql # clear sql script variables
sed -i "1d" insertstmt.sql
sed -i "1d" insertstmt.sql
执行效果:

shell脚本中执行mysql sql脚本文件并传递参数的更多相关文章
- Shell脚本中执行mysql的几种方式(转)
Shell脚本中执行mysql的几种方式(转) 对于自动化运维,诸如备份恢复之类的,DBA经常需要将SQL语句封装到shell脚本.本文描述了在Linux环境下mysql数据库中,shell脚本下调用 ...
- shell 脚本中执行mysql语句
通过hash建表之后,表的数据量巨大2048,那怎么去验证表是否建成功呢? 逻辑生成表名这部分就不写了.只要能建表成功,这部分的脚本肯定是有的.那么怎么在shell中执行selec查询并返回呢 只要在 ...
- shell脚本中执行mysql命令
1.mysql -hhostname -uuser -ppsword -e "mysql_cmd" 2. mysql -hhostname -uuser -ppsword < ...
- shell脚本中执行mysql 语句,去除warning using a password on the command line interface can be insecure信息
方法二:使用mysql参数的方法 mysql -u$user -p$pass -D $db -e "select host from user;"当然,可以通过将传参的方式来传递 ...
- shell脚本循环执行mysql语句
参考资料:Shell脚本中执行mysql语句 需求:数据库里有张数据表存储的是用户对电影的评价(user_id movie_id rating time),但是我现在要每部电影的总评分. 解决方法: ...
- shell执行mysql的脚本(包括mysql执行shell脚本)
在Shell中执行mysql的脚本,这里介绍比较容易使用的一种方法 首先写好sql的脚本,后缀为.sql,比如 sql_file.sql:内容如下 #这是SQL的脚本create table if n ...
- shell脚本中执行python脚本并接收其返回值的例子
1.在shell脚本执行python脚本时,需要通过python脚本的返回值来判断后面程序要执行的命令 例:有两个py程序 hello.py 复制代码代码如下: def main(): pri ...
- Shell脚本中执行sql语句操作mysql的5种方法【转】
对于自动化运维,诸如备份恢复之类的,DBA经常需要将SQL语句封装到shell脚本.本文描述了在Linux环境下mysql数据库中,shell脚本下调用sql语句的几种方法,供大家参考.对于脚本输出的 ...
- mysql中如何在命令行中,执行一个SQL脚本文件?
需求描述: 在mysql数据库的使用中,有的时候,需要直接在shell的命令行中,执行某个SQL脚本文件, 比如,要初始化数据库,创建特定的存储过程,创建表等操作,这里进行一个基本的测试. 一般情况, ...
随机推荐
- ContextLoaderListener解析
推荐:spring源码 每一个整合spring框架的项目中,总是不可避免地要在web.xml中加入这样一段配置. <!-- Spring配置文件开始 --> <context-par ...
- 深入理解RocketMQ的消费者组、队列、Broker,Topic
1.遇到的问题:上测试环境,上次描述的鸟问题又出现了,就是生产者发3条数据,我这边只能收到1条数据. 2.问题解决: (1)去控制台看我的消费者启动情况,貌似没什么问题 , (2)去测试服务器里看日志 ...
- 为什么 MySQL 索引要使用 B+树而不是其它树形结构?比如 B 树?
一个问题? InnoDB一棵B+树可以存放多少行数据?这个问题的简单回答是:约2千万 为什么是这么多呢? 因为这是可以算出来的,要搞清楚这个问题,我们先从InnoDB索引数据结构.数据组织方式说起. ...
- 六.搭建基本的Web服务
1.安装httpd软件包 ]# yum -y install httpd 2.重起httpd服务 ]# systemctl restart httpd ]# systemctl enable http ...
- am335x system upgrade kernel ec20 simcom7600ce(十一)
1 Scope of Document This document describes 4G hardware design, support quectel ec20 4G module/ ...
- [HAOI2015][bzoj 4033]树上染色(树dp+复杂度分析)
[题目描述]有一棵点数为N的树,树边有边权.给你一个在0~N之内的正整数K,你要在这棵树中选择K个点,将其染成黑色,并将其他的N-K个点染成白色.将所有点染色后,你会获得黑点两两之间的距离加上白点两两 ...
- 交互设计算法基础(3) - Quick Sort
int pivotIndex, pivot, swapIndex; void swap(int[] arr, int x, int y) { int temp = arr[x]; arr[x] = a ...
- 笔记-读官方Git教程(1)~认识Git
小书匠版本管理 教程内容基本来自git官方教程,认真都了系列的文章,然后对一些重点的记录下来,做了简单的归纳并写上自己的思考. 目录: 1.Git介绍 2.Git版本控制原理 3.Git特点 4.Gi ...
- CSP-S2019 快乐爆0
hhh 我爆0了 快乐 大家都比我强 hh 常规操作 本来就是个憨憨 回去复习文化课了 唉 干啥啥不行
- ROS里程计
gmapping导航建图包里建图需要里程计信息,且导航也需要. 整个移动机器人的控制结构如下图所示,其中base_controller节点将订阅的cmd_vel信息通过串口或其它通信接口发送给下位机( ...