Linux脚本编辑excel,linux脚本实现excel文件内容读取到数据库

linux读取excel转化为SQL插入语句

假设我现在有一个表,需要插入excel的数据

创建表的代码如下

CREATE TABLE student(

sid VARCHAR(10),

sname VARCHAR(20),

sgender CHAR(1),

sage INT

)

现在要从excel导入数据

cf73395e4385ea623e472b5eca0bd8d6.png

首先我们可以把数据转化成csv或者txt,这里我用csv做例子

e5f4936bf1d0b12fd3284ea185d27310.png

查看这个文件

ef951ff11a80910268d0d7c3402a9085.png

可以看到csv是用逗号分隔的

以下是shell脚本

# !/bin/bash

# read file an create INSERT statements for MYSQL

out=‘stu.sql‘

IFS=‘,‘

while read sid sname sgender sage

do

cat >> $out << EOF

INSERT INTO student (sid,sname,sgender,sage)VALUES

(‘$sid‘,‘$sname‘,‘$sgender‘,‘$sage‘);

EOF

done

其中IFS叫做内部字段分隔符(internal field separator),默认是空格换行和tab键

是追加重定向

72597c929ec3d17ab93622ed5fdf047d.png

需要加可执行的权限

chmod u+x stu.sh

执行代码

./stu.sh < stu.CSV

cat stu.sql

76ae527376bb94fbe51a580fe249b91f.png

可以发现csv文件已经写入到了stu.sql文件之中。

stu.sql文件内容如下

INSERT INTO student (sid,sname,sgender,sage)VALUES

(‘1001‘,‘yangmi‘,‘f‘,‘20

‘);

INSERT INTO student (sid,sname,sgender,sage)VALUES

(‘1002‘,‘pengyueyan‘,‘m‘,‘40

‘);

INSERT INTO student (sid,sname,sgender,sage)VALUES

(‘1003‘,‘huge‘,‘m‘,‘36

‘);

INSERT INTO student (sid,sname,sgender,sage)VALUES

(‘1004‘,‘luhan‘,‘m‘,‘37

‘);

然后运行sql文件就插入到了表中。

以上所有文件点这里下载

原文:https://www.cnblogs.com/realwuxiong/p/12941075.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值