<linux shell 攻略> 庖丁解牛 mysql数据库脚本管理系统

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:
原创作品,允许转载,转载时请务必以超链接形式标明文章  原始出处 、作者信息和本声明。否则将追究法律责任。 http://dba10g.blog.51cto.com/764602/1610703


操作界面


wKiom1TPEynz5sHJAAJnQpUCZlg554.jpg


这个小系统一共包含4个脚本

sh
功能
备注
oneKey.sh 主程序,调用其他程序,对外提供功能

menu.sh 勾画菜单

function.sh 提供操作数据库接口

valid.sh 操作mysql数据库,验证数据


menu.sh 

画字符菜单

1
2
3
4
5
6
7
8
9
10
11
12
13
14
#!/bin/bash
function  print_main_menu(){
cat  <<EOF
#######################################
#    1)创建数据库                  #
#    2)导入电商端数据              #
#    3)创建电商端数据库并导入数据  #
#    4)验证电商端数据数据有效性    #
#    5)删除数据库                  #
#    6)打印菜单                    #
#    7)退出                        #
#######################################
EOF
}


function.sh

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
#!/bin/bash
#作者:
#版本:v1.0
#用途:创建mysql 数据库和数据库表
 
 
#创建数据库 4个必须参数(user,password,database_name,charset)
function  create_database_01(){
     USER= "$1"
     PASSWORD= "$2"
     IP= "$3"
     DATEBASE_NAME= "$4"
     DATABASE_CHARSET= "utf8"
     mysql -h $IP -u $USER -p$PASSWORD <<EOF 2> /dev/null
     create database $DATEBASE_NAME charset=$DATABASE_CHARSET;
EOF
 
     if  [[ $? - eq  0 ]];  then
             echo  "数据库" $DATEBASE_NAME "创建成功"
         else
             echo  "数据库" $DATEBASE_NAME "创建失败"
             exit  1;
     fi
}
 
#扫描地区目录中数据库文件夹,按顺序执行
function  init_database_02(){
     USER= "$1"
     PASSWORD= "$2"
     IP= "$3"
     DATEBASE_NAME= "$4"
     AREACODE= "$5"
     while  read  line; 
     do
         mysql -h $IP -u $USER -p$PASSWORD $DATEBASE_NAME <$line 2> /dev/null
     done  < <( ls  ./$AREACODE/*.sql -rt)
 
     if  [[ $? - eq  0 ]];  then
             echo  "往" $DATEBASE_NAME "导入数据成功"
         else
             echo  "往" $DATEBASE_NAME "导入数据失败"
             exit  1;
     fi
}
 
#删除数据库
function  drop_database_02(){
     USER= "$1"
     PASSWORD= "$2"
     IP= "$3"
     DATEBASE_NAME= "$4"
     mysql -h $IP -u $USER -p$PASSWORD <<EOF 2> /dev/null
     drop database $DATEBASE_NAME;
EOF
 
     if  [[ $? - eq  0 ]];  then
             echo  "数据库" $DATEBASE_NAME "删除成功"
         else
             echo  "数据库" $DATEBASE_NAME "删除失败"
             exit  1;
     fi
}
 
 
#读取参数
function  readstdin(){
             read  -p  "please input ip[localhost]:"  ip
             if  [[ -z  "$ip"  ]];  then
                 ip= "localhost"
             fi
             read  -p  "please input db login user[root]:"  username
             if  [[ -z  "$username"  ]];  then
                 username= "root"
             fi
             read  -p  "please input db login password:"  password
             read  -p  "please input db name:"  dbname    
 
}


valida.sh

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
#!/bin/bash
dbname= "test_jd_dspt_wh"
nsrsbh= "420112568371402"
 
mysql= "mysql -h 192.168.15.9 -u root -p123456 $dbname"
#$mysql "use $dbname"
sql=" select  count(nsrsbh) into @v01 from dj_nsrxx 
where nsrsbh=$nsrsbh;
select  if (@v01<=0, '纳税人识别号在dj_nsrxx表中没有记录' ,
                   '验证01[纳税人识别号在dj_nsrxx表中存在]验证通过!!!' );
select  dsptbm into @dsptbm  from dj_nsrxx where nsrsbh=$nsrsbh;
select  pt.dsptmc into @dsptmc from dj_dzswpt_kz kz ,dj_dzswpt pt 
where  kz. id  =pt. id   and kz.dsptbm=@dsptbm;
select  if (@dsptmc is not null,concat( '验证02通过纳税人电商平台信息:' ,@dsptmc), '验证02[纳税人电商平台信息为空]验证不通过!!!' );
 
select  hy_dm into @vhy  from dj_nsrxx where nsrsbh=@vnsrsbh;
select  kpzt into @vkpzt  from dj_nsrxx where nsrsbh=@vnsrsbh;
select  nsrzt_dm into @vnsrzt from dj_nsrxx where nsrsbh=@vnsrsbh;
select  if (@vhy!=5200, '纳税人行业代码不等于5200' , '验证03[纳税人行业代码等于5200]验证通过!!!' );
select  if (@vnsrzt!=21, '纳税人状态代码不等于21' , '验证04[纳税人状态代码等于21]验证通过!!!' );
select  if (@vkpzt!=1, '纳税人开票状态不等于1' , '验证05[纳税人开票状态等于1]验证通过!!!' );
 
SELECT COUNT(1) into @nsrztcount FROM fp_nsrzt WHERE SWJG_DM = (SELECT SZ_SWJG_DM FROM dj_nsrxx WHERE NSRSBH = @vnsrsbh) AND NSRZT_DM = @vnsrzt;
select  if (@nsrztcount<=0, '纳税人税务机关[SZ_SWJG_DM]不存在或状态与纳税人信息不匹配' , '验证06[纳税人所在税务机关SZ_SWJG_DM有效]验证通过!!!' );
 
select  '上述所有验证均通过,可保证订单可以下发成功' ;
 
select  count(1) into @vjccount2 from fp_pz pz, fp_nsrjc jc where jc.NSRSBH=pz.NSRSBH and pz.FPZL_DM=jc.FPZL_DM and pz.NSRSBH=@vnsrsbh;
select  if (@vjccount2<=0, '纳税人票种或结存为空' , '验证07[纳税人开票结存]验证通过!!!' );
 
select  count(1) into @dymbcount from dm_dymb mb where SWJG_DM=( select  SZ_SWJG_DM from dj_nsrxx where nsrsbh=@vnsrsbh);
select  if (@dymbcount<4, '所在税务机关打印模板数目不足4个' , '验证08[打印模板]验证通过,不保证模板路径有效!!!' );
select  concat( '____' ,PYFILEURL) as  '打印模板如下'  from dm_dymb mb where SWJG_DM=( select  SZ_SWJG_DM from dj_nsrxx where nsrsbh=@vnsrsbh);
 
select  qzid into @vqzid from fp_qzcx where nsrsbh=@vnsrsbh;
select  if (@vqzid is null, '纳税人签章信息不存在' , '验证09[签章信息]验证通过!!!' );
";
$mysql -N -L -s -e  "$sql"


本文出自 “简单” 博客,请务必保留此出处http://dba10g.blog.51cto.com/764602/1610703

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
10月前
|
存储 缓存 文件存储
如何保证分布式文件系统的数据一致性
分布式文件系统需要向上层应用提供透明的客户端缓存,从而缓解网络延时现象,更好地支持客户端性能水平扩展,同时也降低对文件服务器的访问压力。当考虑客户端缓存的时候,由于在客户端上引入了多个本地数据副本(Replica),就相应地需要提供客户端对数据访问的全局数据一致性。
31128 65
如何保证分布式文件系统的数据一致性
|
11月前
|
前端开发 容器
HTML5+CSS3前端入门教程---从0开始通过一个商城实例手把手教你学习PC端和移动端页面开发第8章FlexBox布局(上)
HTML5+CSS3前端入门教程---从0开始通过一个商城实例手把手教你学习PC端和移动端页面开发第8章FlexBox布局
17588 8
|
10月前
|
人工智能 负载均衡 网络性能优化
灵骏可预期网络:Built for AI Infrastructure
通用人工智能离我们越来越近,全世界的关注和投入正在带来日新“周”异的变化。回顾人工智能的诞生和发展历程,人类计算能力的进步几乎牵动了每一次的重大技术突破,当前的大模型热潮更是如此,只是动辄千万亿参数级的模型体量,所需计算资源远超单颗芯片的上限,超大规模的计算集群成为支撑技术发展和应用创新的关键基础设施。面向智能:云基础设施网络技术面临新挑战如何突破单个芯片、单个服务器节点的算力上限,在超大规模情况
29914 6
灵骏可预期网络:Built for AI Infrastructure
|
10月前
|
设计模式 存储 监控
设计模式(C++版)
看懂UML类图和时序图30分钟学会UML类图设计原则单一职责原则定义:单一职责原则,所谓职责是指类变化的原因。如果一个类有多于一个的动机被改变,那么这个类就具有多于一个的职责。而单一职责原则就是指一个类或者模块应该有且只有一个改变的原因。bad case:IPhone类承担了协议管理(Dial、HangUp)、数据传送(Chat)。good case:里式替换原则定义:里氏代换原则(Liskov 
35892 13
设计模式(C++版)
|
10月前
|
存储 编译器 C语言
抽丝剥茧C语言(初阶 下)(下)
抽丝剥茧C语言(初阶 下)
|
11月前
|
机器学习/深度学习 人工智能 自然语言处理
带你简单了解Chatgpt背后的秘密:大语言模型所需要条件(数据算法算力)以及其当前阶段的缺点局限性
带你简单了解Chatgpt背后的秘密:大语言模型所需要条件(数据算法算力)以及其当前阶段的缺点局限性
24268 9
|
10月前
|
机器学习/深度学习 弹性计算 监控
重生之---我测阿里云U1实例(通用算力型)
阿里云产品全线降价的一力作,2023年4月阿里云推出新款通用算力型ECS云服务器Universal实例,该款服务器的真实表现如何?让我先测为敬!
36373 11
重生之---我测阿里云U1实例(通用算力型)
|
11月前
为笔记本更换固态硬盘的方法
本文介绍为笔记本电脑拆机、更换固态硬盘的具体方法~
17862 40
为笔记本更换固态硬盘的方法
|
10月前
|
SQL 存储 弹性计算
Redis性能高30%,阿里云倚天ECS性能摸底和迁移实践
Redis在倚天ECS环境下与同规格的基于 x86 的 ECS 实例相比,Redis 部署在基于 Yitian 710 的 ECS 上可获得高达 30% 的吞吐量优势。成本方面基于倚天710的G8y实例售价比G7实例低23%,总性价比提高50%;按照相同算法,相对G8a,性价比为1.4倍左右。
|
11月前
|
存储 算法 Java
【分布式技术专题】「分布式技术架构」手把手教你如何开发一个属于自己的限流器RateLimiter功能服务
随着互联网的快速发展,越来越多的应用程序需要处理大量的请求。如果没有限制,这些请求可能会导致应用程序崩溃或变得不可用。因此,限流器是一种非常重要的技术,可以帮助应用程序控制请求的数量和速率,以保持稳定和可靠的运行。
29631 51