免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 5214 | 回复: 11
打印 上一主题 下一主题

shell 往oracle循环写入数据的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-03-06 11:56 |只看该作者 |倒序浏览
我想在一些日志文件中,查找凡是含有“Error”的,取出该行数据和该文件名,并把该行数据和文件名保存到数据库中,下面的
shell为什么不成功呢?
#!/bin/sh
constr="user/password@DB"
sql=`sqlplus -s ${constr} <<eof
grep "Error" ULOG* | while read LINE
do
  var1=`echo $LINE|awk -F: '{print $1}'`
  var2=`echo $LINE |sed "s/$var1://"`
  insert into test001(filename,filestr)values($var1,$var2);
done
exit;
eof`
echo $sql

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
2 [报告]
发表于 2012-03-06 12:10 |只看该作者
你要让sqlplus解释shell语句?

论坛徽章:
0
3 [报告]
发表于 2012-03-06 12:22 |只看该作者
回复 1# cas0005


    SQLPLUS 没有这样的功能吧。似乎应该像下面这样:
  1. #!/bin/sh
  2. constr="user/password@DB"

  3. grep "Error" ULOG* | while read LINE
  4. do
  5.   var1=`echo $LINE|awk -F: '{print $1}'`
  6.   var2=`echo $LINE |sed "s/$var1://"`
  7.   sqlplus ${constr} <<eof
  8.   insert into test001(filename,filestr)values($var1,$var2);
  9.   exit;
  10. eof
  11. done
复制代码

论坛徽章:
0
4 [报告]
发表于 2012-03-06 14:45 |只看该作者
回复 3# cduedu


   

论坛徽章:
0
5 [报告]
发表于 2012-03-06 14:48 |只看该作者
刚刚学shell几天,我以为把数据库连接放在循环好一点,因为学得把每循环一次就连接一次数据库,性能上太差了,就以为能放在外面。。。。。谁知道是放在里面的,呵呵。谢谢了!
cduedu 发表于 2012-03-06 12:22
回复 1# cas0005

论坛徽章:
71
15-16赛季CBA联赛之同曦
日期:2018-08-23 15:41:42辰龙
日期:2014-08-15 09:07:43狮子座
日期:2014-06-03 13:55:33亥猪
日期:2014-06-02 11:17:08巨蟹座
日期:2014-05-06 10:02:03午马
日期:2014-05-04 08:18:27亥猪
日期:2014-04-29 11:11:32技术图书徽章
日期:2014-04-24 15:51:26技术图书徽章
日期:2014-04-17 11:01:53辰龙
日期:2014-04-15 12:45:46亥猪
日期:2014-04-11 09:06:23射手座
日期:2014-04-01 15:28:10
6 [报告]
发表于 2012-03-06 14:53 |只看该作者
本帖最后由 zhaopingzi 于 2012-03-06 14:53 编辑

你把是所有的insert语句都搞到一个SQL.txt里,然后统一做一个insert不行吗?
sqlplus /nolog <<eof
conn /as sysdba
@sql.txt;
quit
eof

论坛徽章:
0
7 [报告]
发表于 2012-03-06 15:10 |只看该作者
zhaopingzi 发表于 2012-03-06 14:53
你把是所有的insert语句都搞到一个SQL.txt里,然后统一做一个insert不行吗?
sqlplus /nolog


这位兄弟,把insert语句放到SQL.txt里面,怎么把值传进去呢?这个我不会,麻烦告诉我一下呀
具体应该怎么做?

论坛徽章:
71
15-16赛季CBA联赛之同曦
日期:2018-08-23 15:41:42辰龙
日期:2014-08-15 09:07:43狮子座
日期:2014-06-03 13:55:33亥猪
日期:2014-06-02 11:17:08巨蟹座
日期:2014-05-06 10:02:03午马
日期:2014-05-04 08:18:27亥猪
日期:2014-04-29 11:11:32技术图书徽章
日期:2014-04-24 15:51:26技术图书徽章
日期:2014-04-17 11:01:53辰龙
日期:2014-04-15 12:45:46亥猪
日期:2014-04-11 09:06:23射手座
日期:2014-04-01 15:28:10
8 [报告]
发表于 2012-03-06 15:33 |只看该作者
你吧sql语句都在sql.txt里写好,在oracle里:1>@sql.txt     <---代表执行sql.txt里的东东;@后跟脚本的绝对路径,如果你是在当前目录下进入oracle库里的话,@直接跟脚本名就可以了

论坛徽章:
0
9 [报告]
发表于 2012-03-06 15:48 |只看该作者
zhaopingzi 发表于 2012-03-06 15:33
你吧sql语句都在sql.txt里写好,在oracle里:1>@sql.txt


针对这个例子,怎么用把SQL语句放到另一个文件的方法实现的呢?需要传参之类的吗?
#!/bin/sh
grep "Error" ULOG* | while read LINE
do
  var1=`echo $LINE|awk -F: '{print $1}'`
  var2=`echo $LINE |sed "s/$var1://"`
  constr="user/password@DB"
  sql=`sqlplus -s ${constr} <<eof
  insert into test001(filename,filestr)values($var1,$var2);
  exit;
  eof`
done

论坛徽章:
71
15-16赛季CBA联赛之同曦
日期:2018-08-23 15:41:42辰龙
日期:2014-08-15 09:07:43狮子座
日期:2014-06-03 13:55:33亥猪
日期:2014-06-02 11:17:08巨蟹座
日期:2014-05-06 10:02:03午马
日期:2014-05-04 08:18:27亥猪
日期:2014-04-29 11:11:32技术图书徽章
日期:2014-04-24 15:51:26技术图书徽章
日期:2014-04-17 11:01:53辰龙
日期:2014-04-15 12:45:46亥猪
日期:2014-04-11 09:06:23射手座
日期:2014-04-01 15:28:10
10 [报告]
发表于 2012-03-06 16:02 |只看该作者
本帖最后由 zhaopingzi 于 2012-03-06 16:23 编辑

#!/bin/sh
grep "Error" ULOG* | while read LINE
do
  var1=`echo $LINE|awk -F: '{print $1}'`
  var2=`echo $LINE |sed "s/$var1://"`
echo -e "insert into table(filename,filestr) values(\"$var1\",\"$var2\");" >>sql.txt
done
sqlplus "user/password@BD" <<eof
@sql.txt
exit
eof


您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP