shell_62.shell脚本生成一个标准的 SQL INSERT 语句

无论是将文件读入脚本,还是将数据从脚本输出到文件,都会用到文件重定向,这是一种很

常见的操作。本节中的示例脚本两种功能皆有。它会读取 CSV 格式的数据文件,输出 SQL INSERT

语句,并将数据插入数据库。

shell 脚本使用命令行参数指定待读取的 CSV 文件。CSV 格式用于从电子表格中导出数据,

你可以把这些数据库数据放入电子表格,将电子表格保存为 CSV 格式,读取文件,然后创建

INSERT 语句将数据插入 MySQL 数据库。

实现这些操作的脚本如下:

复制代码
$cat test23 
#!/bin/bash 
# read file and create INSERT statements for MySQL 
outfile='members.sql' 
IFS=',' 
while read lname fname address city state zip 
do 
 cat >> $outfile << EOF 
 INSERT INTO members (lname,fname,address,city,state,zip) VALUES 
('$lname', '$fname', '$address', '$city', '$state', '$zip'); 
EOF 
done < ${1} 
$ 

这个脚本很简短。这要感谢文件重定向。脚本中出现了 3 处重定向操作。while 循环使用

read 语句(参见第 14 章)从数据文件中读取文本。注意在 done 语句中出现的重定向符号:

复制代码
done < ${1} 

当运行脚本 test23 时,$1 代表第一个命令行参数,指明了待读取数据的文件。read 语句使

用 IFS 字符解析读入的文本,这里将 IFS 指定为逗号。

脚本中另外两处重定向操作出现在同一条语句中:

复制代码
cat >> $outfile << EOF 

这条语句包含一个输出追加重定向(双大于号)和一个输入追加重定向(双小于号)。输出

重定向将 cat 命令的输出追加到由$outfile 变量指定的文件中。cat 命令的输入不再取自标准

输入,而是被重定向到脚本内部的数据。EOF 符号标记了文件中的数据起止:

复制代码
INSERT INTO members (lname,fname,address,city,state,zip) VALUES 
('$lname', '$fname', 
 '$address', '$city', '$state', '$zip'); 

上述文本生成了一个标准的 SQL INSERT 语句。注意,其中的数据由变量来替换,变量中

的内容则由 read 语句存入。

while 循环基本上一次读取一行数据,然后将这些值放入 INSERT 语句模板中,最后将结果

输出到文件中。

在这个例子中,使用以下脚本作为输入文件:

复制代码
$ cat members.csv 
Blum,Richard,123 Main St.,Chicago,IL,60601 
Blum,Barbara,123 Main St.,Chicago,IL,60601 
Bresnahan,Christine,456 Oak Ave.,Columbus,OH,43201 
Bresnahan,Timothy,456 Oak Ave.,Columbus,OH,43201 
$ 

运行脚本时,显示器上不会有任何输出:

复制代码
$ ./test23 members.csv 
$ 

但是在输出文件 members.sql 中,可以看到以下内容:

复制代码
$ cat members.sql 
INSERT INTO members (lname,fname,address,city,state,zip) VALUES ('Blum','Richard', '123 Main St.', 'Chicago', 'IL', '60601'); 
INSERT INTO members (lname,fname,address,city,state,zip) VALUES ('Blum','Barbara', '123 Main St.', 'Chicago', 'IL', '60601'); 
INSERT INTO members (lname,fname,address,city,state,zip) 
 VALUES ('Bresnahan','Christine', '456 Oak Ave.', 'Columbus', 'OH', '43201'); 
INSERT INTO members (lname,fname,address,city,state,zip) 
 VALUES ('Bresnahan','Timothy', '456 Oak Ave.', 'Columbus', 'OH', '43201'); 
$ 

结果和我们预想的一样。现在可以直接将 members.sql 文件导入 MySQL 数据表中了。

相关推荐
我爱学习好爱好爱1 小时前
Ansible 常用模块详解:yum、service/systemd、copy实战
linux·服务器·ansible
papaofdoudou1 小时前
LINUX VFIO被IOMMUFD取代
linux·运维·服务器
平生不喜凡桃李2 小时前
浅谈 Linux 中 namespace 相关系统调用
java·linux·服务器
无忧智库2 小时前
智慧医院的“新基建”:从顶层设计到全栈式智能运维的深度解构(PPT)
大数据·运维
YMWM_2 小时前
【问题】thor上的cubLas
linux·python·thor
虾..3 小时前
多路复用 --- select系统调用
服务器·数据库·sql
杨云龙UP3 小时前
mysqldump逻辑备份文件恢复总结:全库恢复、单库恢复,一篇讲明白
linux·运维·服务器·数据库·mysql·adb
舰长1153 小时前
linux系统服务器加固1、中风险 未设置登录失败处理功能和登录连接超时处理功能。2、中风险 未限制默认账户的访问权限。3、中风险 未实现管理用户的权限分离。
linux·运维·服务器
mounter6254 小时前
Linux 7.0 重磅更新:详解 nullfs 如何重塑根文件系统挂载与内核线程隔离
linux·运维·服务器·kernel
色空大师4 小时前
【网站搭建实操(一)环境部署】
java·linux·数据库·mysql·网站搭建