【发布时间】:2016-01-21 14:35:08
【问题描述】:
set verify off
accept project prompt ' project : '
select locknr,description,couserid,ciuserid from dgdtw_lockedinfo where
description = '&project' and ciuserid is null;
accept lock prompt ' locknumber : '
update dgdtw_lockedinfo set ciuserid = couserid where locknr = &lock;
update dgdtw_topografie set locknr = '' where locknr = &lock;
update dgdtw_topografie set verval=sysdate where id= &lock;
commit;
accept var prompt 'repeat process? [Y/N] ? '
define doit = 'H:\Scripts\stop.sql'
column doit new_value doit noprint
set termout off
select 'H:\Scripts\unlock.sql' doit from dual where upper('&var') like 'Y%';
set termout on
start &doit.
我需要一个循环脚本,所以如果项目为空或错误,脚本会要求重复或停止。 比如:
accept var prompt 'project number is wrong try again? [Y/N] ? '
直到项目编号正确或答案为“N”
【问题讨论】:
-
sql*plus 有点交互性,但循环是在服务器上作为块执行的 pl/sql 构造,因此您不能与它们进行持续的用户交互。也就是说 - 可以按照此处所示完成,但我不确定这是一个很好的选择:stackoverflow.com/questions/1870670/…