Shell脚本中时间处理

1.脚本内容

#!/bin/bash

#环境变量

#设置环境变量和sql文件格式相符

source /etc/profile
export LD_LIBRARY_PATH="/usr/lib/oracle/12.1/client64/lib"

export NLS_LANG="AMERICAN_AMERICA.ZHS16GBK"

export LANG=en_US.UTF-8

date=`cat /home/oracle/channelMonitoring/date/trade_zf`

sysdate=`date +"%s"`

date2=`date +"%s" -d "${date}"`

x=`expr \${date2} - \${sysdate}`

if [ $x -lt 1800 ]; then

#初始变量

CHECKORAHOST=172.16.219.101

FILEDIR="/home/oracle/channelMonitoring"

SQLDIR="${FILEDIR}/sql/trade_zf.sql"

DATADIR="${FILEDIR}/data/trade_zf.txt"

DATEFLAG="/home/oracle/channelMonitoring/date/trade_zf"

cat /dev/null >  ${SQLDIR}

cat /dev/null >  $DATADIR

echo -n "select  ('trade_zf'||',trade_code='||tr.trade_code||',status='||tr.status||',merchant='||m.merchant_code||',channel='||tr.bank_code||',bank='||tr.fld3||' value='||(case when tr.status=2 then 1 else 0 end)||' '||ceil((tr.trade_end_time - to_date('1970-01-01','yyyy-mm-dd'))*86400 - TO_NUMBER(SUBSTR(TZ_OFFSET(sessiontimezone),1,3))*3600)||round(dbms_random.value(100000000,999999999)) ) as \"插入语句\" from tvpay2.trade_record tr

join tvpay2.merchant m on tr.provider_id = m.id

where (tr.trade_code  like 'ZF%' or tr.trade_code = 'DK0003' or tr.trade_code = 'DK0026' ) and ((to_date('$date', 'yyyy-mm-dd hh24:mi:ss')-to_date('1970-01-01','yyyy-mm-dd hh24:mi:ss'))*86400 - (tr.trade_end_time-to_date('1970-01-01','yyyy-mm-dd hh24:mi:ss'))*86400) between 0 and  1800 and tr.status in (2,3);

" >> $SQLDIR

sqlplus -s user/password@x.x.x.x:1521/orcl<<EOF

set echo off;

set feedback off;

set head off;

set pagesize 0;

set linesize 433;

set termout off;

define fi1= '${DATADIR}'

prompt *** Spooling to &fi1

spool &fi1

@${SQLDIR};

spool off;

exit;

EOF

sed  -i  's/[ \t]*\$//g'  ${DATADIR}

curl -i -XPOST 'http://x.x.x.x:8086/write?db=monitor' --data-binary @${DATADIR}

date2=`date +"%s" -d "${date}"`

date3=1800

nextdate=`expr \$date2 + \$date3`

echo $nextdate

nextdate=`date -d @${nextdate} "+%Y-%m-%d %H:%M:%S"`

cat /dev/null > ${DATEFLAG}

echo \${nextdate}  >> ${DATEFLAG}

else

echo "已经执行过了,请过30分钟之后在执行。"

fi

2.注意事项

2.1清空文件

cat /dev/null > 目标文件                           ###echo "" > 目标文件有空行

2.2shell调用sql文

汉字以及双引号需要使用转义字符\字符

2.3sql文调用shell变量

‘${date}’ 需要加单引号

2.4算法使用

expr 以及if语句中的判断使用lt

###备注

export LD_LIBRARY_PATH="/usr/lib/oracle/12.1/client64/lib"

在定时任务中,没有这行,可能执行会报错

###备注

export NLS_LANG="AMERICAN_AMERICA.UTF8"

放在配置文件中,防止中文乱码

start_seconds=\$(date --date="\$starttime" +%s)

如何将一个时间格式的变量变换成秒

Shell脚本中时间处理的更多相关文章

  1. shell脚本中>/dev/null的含义

    shell脚本中>/dev/null的含义 shell脚本中有段使用sqlplus的部分: sqlplus ${user_id} <<! >/dev/null spool sp ...

  2. Shell脚本中的并发(转)

    转自http://blog.csdn.net/wangtaoking1/article/details/9838571 主要记录一下Shell脚本中的命令的并发和串行执行. 默认的情况下,Shell脚 ...

  3. linux,shell脚本中获取脚本的名字,使用脚本的名字。

    需求描述: 写shell脚本的过程中,有时会需要获取脚本的名字,比如,有的时候,脚本 中会有usage()这种函数,可能就会用到脚本的名字. 实现方法: shell脚本中,通过使用$0就可以获取到脚本 ...

  4. 转 在shell脚本中使用expect实现scp传输问题

    1.安装expect expect用于shell脚本中自动交互,其是基于tcl编程语言的工具.所以安装expect首先安装tcl.本文中使用的是expect5.45和tcl8.6.6. 安装tcl [ ...

  5. shell脚本介绍、shell脚本结构和执行、date命令用法、shell脚本中的变量

    7月11日任务 20.1 shell脚本介绍20.2 shell脚本结构和执行20.3 date命令用法20.4 shell脚本中的变量 20.1 shell脚本介绍 1.shell脚本语言是linu ...

  6. Linux centosVMware shell脚本介绍、shell脚本结构和执行、date命令用法、shell脚本中的变量

    一. shell脚本介绍 shell是一种脚本语言 aming_linux blog.lishiming.net 可以使用逻辑判断.循环等语法 可以自定义函数 shell是系统命令的集合 shell脚 ...

  7. shell脚本中的各种表达式介绍和使用

    #前言:在shell脚本中,有各种的表达式,包括有条件测试表达式,文件表达式,字符串表达式,整数表达式,接下来我们来了解一下他们的使用方法 1.条件测试表达式 #首先来看一下条件测试语法 #条件测试语 ...

  8. 详解Linux交互式shell脚本中创建对话框实例教程_linux服务器

    本教程我们通过实现来讲讲Linux交互式shell脚本中创建各种各样对话框,对话框在Linux中可以友好的提示操作者,感兴趣的朋友可以参考学习一下. 当你在终端环境下安装新的软件时,你可以经常看到信息 ...

  9. shell脚本中的反引号使用 `

    反引号是~的英文切换 在shell脚本中,反引号允许将shell命令的输出赋值给变量. test=`date` 这样shell会执行反引号中的命令.并将执行的结果赋值给变量tests.

随机推荐

  1. opencv3.1 压缩并拼图

    必须有重叠才能拼,压缩越多,拼接越快 #include <opencv2\opencv.hpp> #include <opencv2\stitching.hpp> using ...

  2. [Xcode 实际操作]七、文件与数据-(24)真机使用无线网络调试应用程序

    目录:[Swift]Xcode实际操作 本文将演示如何通过无线网络,在真机上测试应用程序. 首先通过数据线,将移动设备和电脑连接, 然后点击顶部的[Window]窗口菜单, ->[Devices ...

  3. Apache配置https启动不了的解决办法

    配置咱就不多说了,网站一搜一大堆,在这就谈谈Apache引入“http-ssl.conf”文件后无法启动问题吧 去掉#Include conf/extra/httpd-ssl.conf前面的注释Apa ...

  4. bzoj4300 绝世好题 【dp】By cellur925

    题目描述: 给定一个长度为\(n\)的数列\(a\),求\(a\)的子序列\(b\)的最长长度,满足bi&bi-1!=0(\(2<=i<=len\)). 90分做法: 并没有部分分 ...

  5. jave 计算音视频时长

    File source = new File("视频.mp4"); Encoder encoder = new Encoder(); try { MultimediaInfo in ...

  6. 17.TLB

    我们只想读4个字节,但我们要经过如下的步骤 读取 字节的PDE 读取 字节的 PTE 读取 字节(int 占用4字节)的物理内存 在 10-10-12 分页模式下,CPU 每次要访问额外的访问 8 字 ...

  7. 蓝牙硬件交互数据传输Demo

    #import "ViewController.h" #import <CoreBluetooth/CoreBluetooth.h> @interface ViewCo ...

  8. SNMP消息传输机制

    1.引言 基于TCP/IP的网络管理包含3个组成部分: 1) 一个管理信息库MIB(Management Information Base).管理信息库包含所有代理进程的所有可被查询和修改的参数.RF ...

  9. IDEA自定义设置快捷键输出你想要的语句!

    转载,侵权必删 用Eclipse时间长了, 就习惯之前的快捷键! 当然, IDEA不愧是Java开发的”利器”! 写起代码就是一个字 – “爽”! 建议大家可以去尝试一下! 当然, 在IDEA中输出S ...

  10. Brackets前端开发编辑器

    http://www.cnblogs.com/xiazdong/p/3550148.html http://blog.csdn.net/shinesun001/article/details/5348 ...