在 Oracle 9i 中,在命令行程序中。如何计算前一个和最后一个dbms_output.put_line
之间受影响的行数(更新/删除/插入)?BEGIN
COMMIT
另外,如何打印执行指令的数量(DML,DDL)?
在 Oracle 9i 中,在命令行程序中。如何计算前一个和最后一个dbms_output.put_line
之间受影响的行数(更新/删除/插入)?BEGIN
COMMIT
另外,如何打印执行指令的数量(DML,DDL)?
没有简单的方法可以获取执行的语句数或受影响行的累积计数。您需要添加代码来自己跟踪。对于语句的数量,您每次执行时只需将一个变量添加到变量中即可。对于受影响的行数,您可以使用SQL%ROWCOUNT 隐式游标属性:
declare
statement_count pls_integer := 0;
total_row_count pls_integer := 0;
begin
insert into my_table (id) values (1);
statement_count := statement_count + 1;
total_row_count := total_row_count + SQL%ROW_COUNT;
dbms_output.put_line('Rows affected by statement ' || statement_count
|| ': ' || SQL%ROWCOUNT);
update my_table set id = id + 1;
statement_count := statement_count + 1;
total_row_count := total_row_count + SQL%ROW_COUNT;
dbms_output.put_line('Rows affected by statement ' || statement_count
|| ': ' || SQL%ROWCOUNT);
delete from my_table where id = 2;
statement_count := statement_count + 1;
total_row_count := total_row_count + SQL%ROW_COUNT;
dbms_output.put_line('Rows affected by statement ' || statement_count
|| ': ' || SQL%ROWCOUNT);
dbms_output.put_line('Number of statements: ' || statement_count);
dbms_output.put_line('Total rows affected: ' || total_row_count);
end;
/
如果您只对提交的值感兴趣,并且如果您要在中间块中执行该操作,则commit
需要重置计数器;rollback
尽管这通常不是必需的,也不是一个好主意。