免费注册 查看新帖 |

Chinaunix

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

请问怎么在脚本中取得oracle数据库中的值 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-03-16 10:50 |只看该作者 |倒序浏览
比如:select 1+1 from dual; 这个在数据库中得到的值为2,我想把这个2赋值给我的一个变量param1,我的作用就是取数据库中一个表中的一个值想把它传一个变量。谢谢了

论坛徽章:
0
2 [报告]
发表于 2010-03-16 11:06 |只看该作者
shell 中不行吧。
在perl中fetchrow_arrary
详细看perl的DBI模块。

论坛徽章:
0
3 [报告]
发表于 2010-03-16 11:09 |只看该作者
perl我不会哦,用脚本有没有方法了,谢谢各位了。

论坛徽章:
0
4 [报告]
发表于 2010-03-16 11:34 |只看该作者
result=`sqlplus <<-!!!

    select 1+1 from dual;
!!!`

应该就可以了。

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
5 [报告]
发表于 2010-03-16 11:36 |只看该作者
回复 2# suxingwakeup


Shell里面调用sqlplus可以实现,方法见4楼,如果需要身份验证,在sqlplus后面加上用户名和密码即可。

论坛徽章:
1
数据库技术版块每日发帖之星
日期:2016-01-24 06:20:00
6 [报告]
发表于 2010-03-16 11:48 |只看该作者
  1. param1=`sqlplus -s test/test<<EOF
  2. set heading off
  3. set feedback off
  4. set pagesize
  5. set trimout on
  6. select to_char(1+1) from dual; --数字的话输出行首会有空格,所以转成字符串了
  7. exit
  8. EOF`
复制代码
或者通过sqlplus的spool命令输出到文件,处理文件得到想要的结果也可以。

论坛徽章:
0
7 [报告]
发表于 2010-03-16 11:51 |只看该作者
  1. type2@linux182:~> sqlplus / as sysdba <<EOF
  2. > select * from v\$controlfile;
  3. > EOF
复制代码
不过你还得用AWK截取后才能给变量

论坛徽章:
0
8 [报告]
发表于 2010-03-16 12:08 |只看该作者
运行报错,能不能给个这样的例子了,谢谢各位了

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
9 [报告]
发表于 2010-03-16 12:54 |只看该作者
4楼报错还是6楼报错?报啥错?

论坛徽章:
0
10 [报告]
发表于 2010-03-16 17:49 |只看该作者

  1. #! /bin/bash

  2. result=$(awk '{if($1=="1+1") got=1; if(got==1) count++; if(count==3) print $1}' <(sqlplus / as sysdba <<EOF
  3.     select 1+1 from dual;
  4. EOF))
  5. echo $result;
复制代码
数据库查出的值保存在result中
不太熟悉awk还,也许有更好的法子
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP