免费注册 查看新帖 |

Chinaunix

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

求助:如何在SQL语句中引用在操作系统上定义的变量? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-04-20 17:40 |只看该作者 |倒序浏览
例如:在操作系统上定义了一个变量id=12,是否可以在查询时使用如下语句:select * from table1 where user_id=12;如果不可以应该怎样引用?

论坛徽章:
0
2 [报告]
发表于 2010-04-20 17:45 |只看该作者
操作系统上定义变量就是操作系统的变量   数据库定义变量是数据库变量 不一样的,不知道你这个SQL是在什么地方运行?是sqlplus吗?

论坛徽章:
0
3 [报告]
发表于 2010-04-20 17:52 |只看该作者
是的,要从sqlplus运行。请问有什么好办法么?

论坛徽章:
0
4 [报告]
发表于 2010-04-21 13:53 |只看该作者
test.sql:

declare
begin
dbms_output.put_line(&1);
end;
/


SQL> @e:\test\test.sql 123
123

PL/SQL procedure successfully completed.

SQL>

论坛徽章:
0
5 [报告]
发表于 2010-04-21 14:34 |只看该作者
写好脚本 像楼上那样 &

论坛徽章:
0
6 [报告]
发表于 2010-04-27 13:35 |只看该作者
谢谢,各位的回复

论坛徽章:
0
7 [报告]
发表于 2010-05-06 09:16 |只看该作者
我比较多的是写shell脚本互交
  1. cd  /home/oracle/_monitor
  2. rm  ./rereport.log
  3. cat  ./.sys.para  | while read area dbsig
  4. do
  5. use=`echo $dbsig | cut -c 1-2 | tr [A-Z] [a-z]`

  6. sqlplus -s <<@ |tee  ./rereport.log
  7. monitor/monitor@$dbsig
  8.         ! echo "==in $area=="
  9.         set  head off
  10.         col  LAST_NUMBER for  999,999,999,999,999
  11.         select SEQUENCE_NAME ,LAST_NUMBER  from  ${use}tv.user_sequences;
  12. @
  13. done
复制代码

论坛徽章:
0
8 [报告]
发表于 2010-05-24 20:29 |只看该作者
define也可以

SQL> define x=8;
SQL> insert into test values(;

已创建 1 行。

SQL> select * from test;

        ID
----------
         8

SQL> select count(*) from test where id=&x;
原值    1: select count(*) from test where id=&x
新值    1: select count(*) from test where id=8

  COUNT(*)
----------
         1

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

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP