oracle中@和@@的区别

@和start是一个东西,他们用于运行其它的脚本文件

@@也是运行其它的脚本文件

他们的不同之处在于路径的问题

在D:\a目录下创建以下两个文件

--------------------1.sql---------------------

@2.sql

--------------------2.sql--------------------

select 1 from dual;

D:\>sqlplus username/passwd@oracle

SQL>@/a/1.sql

SP2-0310:无法打开文件“2.sql"

将1.sql文件修改成@@2.sql后在执行以上语句

SQL>@/a/1.sql

1

-------------

1

SQL>

执行成功了,这里第一次执行@/a/1.sql的时候,当前的工作路径其实并没有改变,还是在D盘,然后执行1.sql里面的@2.sql的时候他是在d盘寻找2.sql文件,因此报错,而改为@@后,意味着,在本次调用中请假设当前目录已经改成了当前执行文件所在目录


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值