文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

用shell把执行的两条sql语句相加并输出数据库名和相加的值以tab健隔开

2024-04-02 19:55

关注

SELECT SUM(PresentSum) FROM `Lg_ConsumeDetail0` WHERE ConsumeDate < '2016-11-01' AND OpId != 300;

+

SELECT SUM(PresentSum) FROM `Lg_ConsumeDetail1` WHERE ConsumeDate < '2016-11-01' AND OpId != 300;


每次返回的是+号上下两句sql查询的和。

注意,有可能其中一句sql返回的是NULL或者报错信息(没有这个表)。

格试如下:

输出结果
数据库名1   sql1+sql2的和
数据库名2   sql1+sql2的和
数据库名3   sql1+sql2的和
...               ...
中间要以tab健隔开 


代码如下:

#!/bin/bash
USER='root'
PASSWD='123456'
IP='192.168.1.1'
for i in  tzpay tzpay360 tzpay_179 tzpay_9377 tzpay_dx2 tzpay_dx3 tzpay_dx4 tzpay_dx5 tzpay_dx6 tzpay_lt1 tzpay_lt2 tzpay_lt3 tzpay_lt4 tzpay_yy
do
  table1=$(mysql -u$USER -p$PASSWD -h$IP $i -e "SELECT SUM(BasicSum) FROM Lg_ConsumeDetail0 WHERE ConsumeDate < '2016-11-01' AND OpId = 300;" | tail -1 | awk '{print $1}')
  table4=$(mysql -u$USER -p$PASSWD -h$IP $i -e 'show tables like "Lg_ConsumeDetail0"' | wc -l)
    
  #判断存不存在表0,不存在则打印表1的值,跳过本次循环 
  if [ $table4  -eq 0  ];then
       mysql -u$USER -p$PASSWD -h$IP $i -e "SELECT SUM(BasicSum) FROM Lg_ConsumeDetail1 WHERE ConsumeDate < '2016-11-01' AND OpId = 300;" | tail -1 | awk '{print b"\t"$1}'
       continue
  fi  
  table2=$(mysql -u$USER -p$PASSWD -h$IP $i -e 'show tables like "Lg_ConsumeDetail1"' | wc -l) 
  
  #判断存不存在表1,不存在则打印表0的值,跳过本次循环  
  if [ $table2 -eq 0 ];then
        mysql -u$USER -p$PASSWD -h$IP $i -e "SELECT SUM(BasicSum) FROM Lg_ConsumeDetail0 WHERE ConsumeDate < '2016-11-01' AND OpId = 300;" | tail -1 | awk -vb=$i '{print b"\t"$1}'
        continue
  fi
  table3=$(mysql -u$USER -p$PASSWD -h$IP $i -e "SELECT SUM(BasicSum) FROM Lg_ConsumeDetail1 WHERE ConsumeDate < '2016-11-01' AND OpId = 300;" | tail -1 | awk '{print $1}')
     
  #判断表1和表0同时为NULL的话,则直接输出NULL,跳过本次循环  
  if [ $table3 == "NULL" ] && [ $table1 == "NULL" ];then
        echo NULL | awk -vb=$i '{print b"\t"$1}'
        continue
  fi
  
  #判断表1为NULL的话,则直接输出表0的值,跳过本次循环  
  if [ $table3 == "NULL" ];then
        mysql -u$USER -p$PASSWD -h$IP $i -e "SELECT SUM(BasicSum) FROM Lg_ConsumeDetail0 WHERE ConsumeDate < '2016-11-01' AND OpId = 300;" | tail -1 | awk -vb=$i '{print b"\t"$1}'
        continue
  fi
  
  #判断表0为NULL的话,则直接输出表1的值,跳过本次循环  
  if [ $table1 == "NULL" ];then
        mysql -u$USER -p$PASSWD -h$IP $i -e "SELECT SUM(BasicSum) FROM Lg_ConsumeDetail1 WHERE ConsumeDate < '2016-11-01' AND OpId = 300;" | tail -1 | awk '{print b"\t"$1}'
        continue
  fi
  
  #上面判断都不存的话,就把表0和表1的值相加输出
  expr $table1 + $table3  | awk -vb=$i '{print b"\t"$1}' 
done


执行结果如下:

[root@10-9-181-186 opt]# sh sql_sum.sh
tzpay   69768460
tzpay360        23185990
tzpay_179       1259110
tzpay_9377      57750
tzpay_dx2       32938190
tzpay_dx3       33270350
tzpay_dx4       12540690
tzpay_dx5       13220880
tzpay_dx6       NULL
tzpay_lt1       33962100
tzpay_lt2       23586690
tzpay_lt3       10345880
tzpay_lt4       NULL
tzpay_yy        NULL


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯