普通用户利用crontab定时执行db2 sql示例

      今天在RHEL 5.3测试了一下普通用户利用crontab定时执行db2 sql情况,走了一些弯路,因为用./可以执行得到正确结果,而crontab却执行得不到,很是郁闷,在网上查了半天,有好多说是/usr/bin/crontab的权限问题
可是我在RHEL 5.3查看并一下
-rwsr-sr-x 1 root root 309K 2007-06-22 /usr/bin/crontab
我的权限是没有问题,后来查了很多资料才知道是DB2环境变量的问题,主要是水平不够,意识不高,写下备用
以db2inst1用户登陆linux系统
1.vi db2inst1cron
* * * * *   /home/db2inst1/tongji.sh >>/home/db2inst1/b.txt
2.crontab db2inst1cron 
3.vi tongji.sh (777)
#!/bin/bash
#tongji  auto
top="20"
qiantian=$top`date -d '2 day ago' +"%y%m%d"`
yesterday=$top`date -d '1 day ago' +"%y%m%d"`
echo "----------------------------------------------"
echo $(date +"%y-%m-%d %H:%M:%S")
echo "-----------------setp1:date--------------------"
echo "qiantian:" $qiantian
echo "yesterday:" $yesterday
echo "-----------------setp2:char---------------------"
#sed -i "s/$qiantian/$yesterday/g" `grep  $qiantian -rl /home/db2inst1/tongji_sec`
echo "----------------step3:dbconnect-----------------"
db2 "connect to toolsdb "
echo "1232312312"
db2 -tf /home/db2inst1/tongji_sec/sql_sec.sql
 
4.vi sql_sec.sql
insert into liuchao values(10);
 
------------------------------------我是分割线---------------------------------------------
a.
[db2inst1@localhost ~]$ ./tongji.sh (正确,是想要结果)
----------------------------------------------
10-03-09 15:37:27
-----------------setp1:date--------------------
qiantian: 20100307
yesterday: 20100308
-----------------setp2:char---------------------
----------------step3:dbconnect-----------------
   Database Connection Information
 Database server        = DB2/LINUXX8664 9.5.3
 SQL authorization ID   = DB2INST1
 Local database alias   = TOOLSDB
1232312312
DB20000I  The SQL command completed successfully.
[db2inst1@localhost ~]$ 
 
b.crontab 执行(错误,无数据库操作,不是想要结果)
----------------------------------------------
10-03-09 15:38:01
-----------------setp1:date--------------------
qiantian: 20100307
yesterday: 20100308
-----------------setp2:char---------------------
----------------step3:dbconnect-----------------
1232312312
 
------------------------------------解决方法--------------------------------------------
#!/bin/bash
#tongji  auto
.  /home/db2inst1/sqllib/db2profile   #引入db2的环境变量(.后面有空格)
top="20"
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值