首页 > 数据库 >shell脚本:对开发入库的sql脚本进行检查

shell脚本:对开发入库的sql脚本进行检查

时间:2023-07-04 16:55:38浏览次数:39  
标签:脚本 shell grep log file sql path txt

shell脚本内容为:

点击查看代码
#!/bin/bash
export LANG=en_US.UTF-8
export NLS_LANG="AMERICAN_AMERICA.AL32UTF8"
source /etc/profile
source /root/.bash_profile

HOME=$(cd $(dirname $0); pwd)
DOC_HOME=${HOME}/releasedoc
DOC_SVN_PATH=http://192.168.xx.xx/bushiahoren/bushiahoren/haoren/doc # 脚本SVN库地址
log_path=${HOME}/tmplog
xls_path=${HOME}/results
keyword=( truncate DELETE "insert.*tables" STORAGE )
DMUSERDIR='ECMS SPG_ATM SPG_SC SPG_TOP XXQA'
curTime=`date +%Y%m%d-%H%M`
xlsname=${xls_path}/inspect_${curTime}.xls
filenames='checkdocdir.txt blankspace.txt checkfiletype.txt enderror.txt partition.txt format.txt catalogue.txt keyword.txt commit.txt sizecomparison.txt'

# 检查目录与拉取代码
function INIT() {
  [ -d ${DOC_HOME} ] || mkdir -p ${DOC_HOME}
  if [ -d ${DOC_HOME}/脚本和操作票 ]; then
    svn update ${DOC_HOME} --username=qinwengang --password=TECHnology@522
  else
    cd ${DOC_HOME}
    svn checkout ${DOC_SVN_PATH} ${DOC_HOME} --username=qinwengang --password=TECHnology@522
  fi

  # 获取未增量到现场的所有文件名
  all_sql_file=$(find ${DOC_HOME}/脚本和操作票/业务脚本 -type f -iname "*.sql" |grep -Ev "已发现场| ")  # 不包含空格文件名
  all_doc_file=$(find ${DOC_HOME}/脚本和操作票/操作票 -type f -iname "*.do" |grep -Ev "已发现场| ")  # 不包含空格文件名

  # 清理已存在文件内容
  for i in $filenames; do
    [ -f ${log_path}/$i ] && echo > ${log_path}/$i
  done

  [ -f ${log_path}/tmpall.txt ] && echo > ${log_path}/tmpall.txt  # 用于xls文件制作
  [ -f ${log_path}/all.txt ] && echo > ${log_path}/all.txt  # 用于xls文件制作
}


# 检查脚本目录是否有新增
function CHECKDOCDIR() {
  for i in $(ls ${DOC_HOME}/脚本和操作票/业务脚本); do
      echo  ${DMUSERDIR} | grep  ${i} >/dev/null 2>&1
      if [ $? != 0 ]; then
          echo "$curTime,新创建得脚本目录请确认,${DOC_HOME}/脚本和操作票/业务脚本/$i" >> ${log_path}/checkdocdir.txt
      fi
  done
}

# 检查文件或者目录是否有空格
function BLANKSPACE(){
  sql_file=$(find ${DOC_HOME} -type f -iname "*.sql" |grep -v '已发现场' | grep -E " ")  # 空格文件sql
  info='包含空格'
  if [ ! -e $sql_file ]; then
    for i in $sql_file; do
      echo "$curTime,$info,$1" >> ${log_path}/blankspace.txt${log_path}/blankspace.txt
    done
  fi

  doc_file=$(find ${DOC_HOME} -type f -iname "*.do*" |grep -v '已发现场' | grep -E " ")  # 空格文件doc
  if [ ! -e $doc_file ]; then
    for i in $doc_file; do
       echo "$curTime,$info,$1" >> ${log_path}/blankspace.txt
    done
  fi
}

# 检查操作票目录下含.sql/业务脚本目录下含.doc
function CHECKFILETYPE(){
  errsql_file=$(find ${DOC_HOME}/脚本和操作票/操作票 -type f -iname "*.sql" |grep -Ev "已发现场| ")  # 不包含空格文件名
  info='文件目录存放错误'
  if [ ! -e $errsql_file ]; then
    for i in $errsql_file; do
      echo "$curTime,$info,$1" >> ${log_path}/checkfiletype.txt
    done
  fi

  errdoc_file=$(find ${DOC_HOME}/脚本和操作票/业务脚本 -type f -iname "*.do" |grep -Ev "已发现场| ")  # 不包含空格文件名
  if [ ! -e $errdoc_file ]; then
    for i in $errdoc_file; do
      echo "$curTime,$info,$1" >> ${log_path}/checkfiletype.txt
    done
  fi
}


# 检查脚本中是否包含PROCEDURE,p_exec,FUNCTION,declare中是否正确以/结尾
# 需要传入脚本名参数
function ENDERROR() {
  # declNum=`grep -vE '^%|^$' $1  |sed  's/^[ \t]*//g'|grep -Ei '^p_exec|PROCEDURE|FUNCTION|^declare|^begin|^end|^/'| grep -ivE 'if;|beginTime|endTime|loop;|/\*|\/\*'|wc -l`
  # 使用关键字+begin+end+'/'的格式进行判断,在出现循环begin+end的特殊情况会出现一些报错
  # 这里使用关键字总数为2的倍数,begin+end数也是2的倍数即可
  tabNum=`grep '\/' $1 |grep -vE '\/\*|\*\/|--'|grep -iEv '[a-z]|[0-9]'|grep -i $'\t'|wc -l`
  info1=""
  if [ ${tabNum} -gt 0 ]; then
    echo "$curTime,'/后带了tab键请删除tab键',$1" >> ${log_path}/enderror.txt
  fi

  declNum=`cat $1 |grep -vE '^%|^$'|sed  's/^[ \t]*//g'|grep -Ei '^p_exec|PROCEDURE|FUNCTION|^declarie'|wc -l`
  if [ $declNum -gt 0 ]; then
    # 该值大于0,表明脚本含有调用数据库函数p_exec,创建procedure或者function,有declare等
    # 这些都表明,脚本必须是正确的结构begin+end;+/
    # 三者排除特殊的字符外加起来行数是3的倍数,存在begin+end的这种组合,排除loop和end if之外
    # 则计数行为3/5/8/11/(只认定begin+end出现一次的情况)
    charNum=`cat $1 | grep -vEi '^%|^$|_end|end_|begin_|_begin|if|loop|beginTime|endTime|end\)|\/\*|\*\/|--' | sed  's/^[ \t]*//g' | grep -iE '^begin|^end.*;$|^/' | wc -l`
    #yushu=$(($charNum % 3))
    if [ $(($charNum % 3)) -gt 0 ]; then
      #if [ $(($charNum % 5)) -gt 0 ]; then
        #if [ $(($charNum % 8)) -gt 0 ]; then
          #if [ $(($charNum % 11)) -gt 0 ]; then
            info1='PROCEDURE或FUNCTION或declare结尾异常'
            echo "$curTime,$info1,$1" >> ${log_path}/enderror.txt
          #fi
        #fi
      #fi
    fi
  fi
}


# 检查创建表是否带分区,不带分区不符合规范,大表才做分区
# 检查创建表或者comment带了双引号,带双引号不符合规范
# 需要闯入脚本名参数
function PARTITION() {
  # 5.cpmment字段出现单引号情况
  comment_num=`cat $1 | sed  's/^[ \t]*//g'|grep -iEn 'COMMENT +ON'|awk '{print $1,$6}'|grep -iE '"'|wc -l`
  if [ $comment_num -gt 0 ]; then
      for i in `cat $1 | sed  's/^[ \t]*//g'|grep -iEn 'COMMENT +ON'|awk '{print $1,$6}'|grep -iE '"'|awk '{print $1}'`
    do
      seq1_num=`echo $i|xargs echo -n|awk -F ':' '{print $1}'`
      echo "$curTime,第$seq_num行的注释使用引号错误,$1" >> ${log_path}/partition.txt
    done
  fi
}


#业务脚本-判断UTF-8格式
# 需要闯入脚本名参数
function FORMAT(){
  grep -P '[\p{Han}]' $1 > /dev/null
  if [[ $? == 0 ]];then
    file_charset=`file -i $1 |awk -F "=" '{print $NF}'`
    [[ ${file_charset} == "utf-8" ]] || echo  "$curTime,为非UTF-8格式:${file_charset},$1" >> ${log_path}/format.txt
  fi
}


#业务脚本-判断目录
# 需要闯入脚本名参数
function CATALOGUE(){
  script_name=`dirname $1`
  dir_name=`dirname $1|awk -F"/" '{print $NF}'`
  [[ ${dir_name} == *hpoms4j-Q* ]] || echo "$curTime,目录不规范,$1" >> ${log_path}/catalogue.txt
}


#业务脚本-判断关键字
# 需要闯入脚本名参数
function KEYWORDS(){
  for j in "${keyword[@]}"; do
    grep -i "$j" $1  >/dev/null
    if [ $? == 0 ]; then
      echo -e "$curTime,含敏感关键字:$j,$1" >> ${log_path}/keyword.txt
      [ $? == 0 ] || exit 111
    fi
  done
}


#业务脚本-commit结尾
# 需要传入脚本名参数
function COMMIT(){
  cat $1 |grep commit >/dev/null
  if [ $? == 0 ];then
    cat $1 |grep commit|grep \; >/dev/null
    if [ $? != 0 ];then
      echo -e "${curTime},commit结尾无分号,$1"  >> ${log_path}/commit.txt
      [ $? == 0 ] || exit 111
    fi
  fi
}


#业务脚本-D、T文件大小对比
# 需要闯入脚本名参数
function SIZE_COMPARISON(){
  ls $1 |grep  "D.sql" > /dev/null && ls $1/ |grep "T.sql" > /dev/null
  if [ $? == 0 ];then
    D_sql=`ls $1 |grep  "D.sql" |sed 's/-//g' |sed 's/_//g'  |awk -F "量" '{print $2}' |awk -F "】" '{print $1}'`
    T_sql=`ls $1 |grep  "T.sql" |sed 's/-//g' |sed 's/_//g'  |awk -F "量" '{print $2}' |awk -F "】" '{print $1}'`
    for i in `echo  "$D_sql"`
    do
      for j in `echo  "$T_sql"`
      do
        if [ $i -le $j ];then
          echo "${curTime},T类型时间戳大于或等于D类型,$1" >> ${log_path}/sizecomparison.txt
          [ $? == 0 ] || exit 111
        fi
      done
    done
  fi
}


# 将检查记录转换成xls格式记录
function RECORDXLS() {
  for i in $filenames; do
    if [ -f $log_path/$i ]; then
      if [ `cat $log_path/$i |grep -ivE '^$'|wc -l` -gt 0 ]; then
        cat $log_path/$i |grep -ivE '^$' >> $log_path/tmpall.txt
      fi
    fi
  done

  if [ -f $log_path/tmpall.txt ]; then
    if [ `cat $log_path/tmpall.txt |grep -ivE '^$'|wc -l` -gt 0 ]; then
      grep -iEv '^==|^&|^%|^$' $log_path/tmpall.txt |sed 's#'"${DOC_HOME}/"'##g' > $log_path/all.txt
      python3.10 $HOME/createexcel.py $log_path/all.txt  $xlsname
    fi
  fi

  find $xls_path -mtime +10 | grep -iE 'xls$' | xargs rm -f
}

#检查是否创建新的脚本目录
function main(){
  # 拉取doc&sql文件
  INIT
  # 检查目录新增
  CHECKDOCDIR
  #检查空格
  BLANKSPACE
  # 检查文件是否位于不该出现得目录
  CHECKFILETYPE

  # 0505
  [[ -e "$all_sql_file" ]] && "echo 没有.sql脚本文件,流程退出 && exit 111"
  for file in $all_sql_file; do
    ENDERROR $file  # 检查某些函数结尾符
    PARTITION $file  # 检查新建表是否分区,大表分区,小表不用分区
    FORMAT  $file  # 检查格式
    CATALOGUE $file  #检查目录 ?????????????
    KEYWORDS $file  # 检查关键字
    COMMIT $file # 检查commit结尾
    SIZE_COMPARISON $file  #D、T文件大小对比
  done

  #打印检查信息
  #PRINT_FILE
  # 将检查记录转换成xls格式记录
  RECORDXLS
}

main 

标签:脚本,shell,grep,log,file,sql,path,txt
From: https://www.cnblogs.com/qinwengang/p/17526190.html

相关文章

  • windows下mysql中binlog日志分析和数据恢复
    1.首先查看是否开启了binlogshowvariableslike'%log_bin%'; 我的已经开启了,如果没开启则开启binlog2.查看有哪些binlog文件和正在使用的binlog文件 查看有哪些binlog文件showbinarylogs;或者showmasterlogs; 查看当前正在使用的是哪一个binlog文件show......
  • kubesphere mysql搭建与测试
    1.搭建kubesphere搭建mysql很简单,直接去应用商店找到mysql安装就可以了。2.搭建情况应用: 服务:工作负载: 容器: 保密字典: 编辑设置找到root密码:xxxxxx3.测试run一个k8smysql客户端bash-5.1#kubectlrun-it--rm--image=mysql:5.7--restart=Nevermysq......
  • 从0开始,手写MySQL数据管理器DM
    文章很长,且持续更新,建议收藏起来,慢慢读!疯狂创客圈总目录博客园版为您奉上珍贵的学习资源:免费赠送:《尼恩Java面试宝典》持续更新+史上最全+面试必备2000页+面试必备+大厂必备+涨薪必备免费赠送:《尼恩技术圣经+高并发系列PDF》,帮你实现技术自由,完成职业升级,薪......
  • textare内容直接存储mysql,怎么原样输出到页面,保留输入的空格 回车换行
    使用thinkcmf时,一个textarea类型的模版变量,配置内容里需要显示换行和多个连续空格。 查看数据库存储json保存数据后是有存储回车换行和多个空格的,只是显示时不显示回车换行,多个连续空格变成了一个空格。使用{$theme_vars.foot1|nb2br}仅能保留回车换行,多个空格只显示一个......
  • linux 换源脚本
    参考https://www.cnblogs.com/cnroadbridge/p/15194989.html gitclonehttps://gitee.com/taoge2021/env-config.gitcdenv-config/linux/ubuntu/sourceschmodu+xchange-sources.sh./change-source.sh......
  • CentOS7使用yum安装MySQL8
    1、下载MySQL的repo源wgethttps://repo.mysql.com//mysql80-community-release-el7-1.noarch.rpm2、安装MySQL源rpm-Uvhmysql80-community-release-el7-1.noarch.rpm3、安装公钥rpm--importhttps://repo.mysql.com/RPM-GPG-KEY-mysql-2022 4、使用yum安装yum......
  • 数据库内核:PostgreSQL 事务
    事务处理事务简介事务是一个应用层面的操作,通过一系列的数据库操作执行。一个事务会影响数据库的状态。对于事务来说,会有很多限制,这些限制实质上是保障整个数据库的状态是合乎标准的,但是在执行事务期间,可能会有一部分限制被打破,但是如果该事务是合法的,那么在完成或放弃当前......
  • 公积金结息计算脚本
    网上查找了好久没有找到公积金结息计算器,所以自己用python写个脚本来实现#去年6月30日公积金余额count=float(10000)l=0.015#月缴存额y=float(700)j=count*lprint("基础利息:{}".format(j))x=0foriinrange(1,13):x=(l*y)/12*ij+=x......
  • 如何正确格式化sqlite shell输出?
    sqlite>.modecolumnsqlite>select*fromfoo;234kshitizdba.sesqlite>.headersonsqlite>select*fromfoo;barbazbaf------------------------------234kshitizdba.seecho-e'.modecolum......
  • PowerShell系列四:容器操作
    容器容器是一个很通用的概念。比如文件、文件夹、注册表、磁盘分区、数组、hash表、命名空间、用户组、OU、数据库、数据表等等,它们的共同点就是包含了数据。在PowerShell中一切都是从"PSDrive"开始的,您熟悉了操作PSDrive,基本就涵盖了对资源的操作。Get-PSDrive#输出Name......