Количество строк, на которые влияет UPDATE в PL/SQL

StackOverflow https://stackoverflow.com/questions/861983

  •  21-08-2019
  •  | 
  •  

Вопрос

У меня есть функция PL/SQL (работающая в Oracle 10g), в которой я обновляю некоторые строки.Есть ли способ узнать, сколько строк было затронуто ОБНОВЛЕНИЕМ?При выполнении запроса вручную он сообщает мне, сколько строк было затронуто, я хочу получить это число в PL/SQL.

Это было полезно?

Решение

Вы используете sql%rowcount переменная.

Вам нужно вызвать его сразу после оператора, для которого вам нужно найти количество затронутых строк.

Например:

set serveroutput ON; 
DECLARE 
    i NUMBER; 
BEGIN 
    UPDATE employees 
    SET    status = 'fired' 
    WHERE  name LIKE '%Bloggs'; 
    i := SQL%rowcount; 
    --note that assignment has to precede COMMIT
    COMMIT; 
    dbms_output.Put_line(i); 
END; 

Другие советы

Для тех, кому нужны результаты простой команды, решением может быть:

begin
  DBMS_OUTPUT.PUT_LINE(TO_Char(SQL%ROWCOUNT)||' rows affected.');
end;

Основная проблема заключается в том, что SQL%ROWCOUNT является переменной (или функцией) PL/SQL и к ней нельзя получить прямой доступ из команды SQL.Этого можно добиться, используя блок PL/SQL без имени.

...Если у кого-нибудь есть решение использовать его в команде SELECT, мне было бы интересно.

альтернативно, SQL%ROWCOUNTвы можете использовать это внутри процедуры без необходимости объявлять переменную

SQL%ROWCOUNT также может использоваться без назначения (по крайней мере, из Оракул 11г).

Пока в текущем блоке не было выполнено никаких операций (обновлений, удалений или вставок), SQL%ROWCOUNT установлено на ноль.Тогда сохраняется номер строки, на которую повлияла последняя операция DML:

скажем, у нас есть таблица CLIENT

create table client (
  val_cli integer
 ,status varchar2(10)
)
/

Мы бы протестировали это следующим образом:

begin
  dbms_output.put_line('Value when entering the block:'||sql%rowcount);

  insert into client 
            select 1, 'void' from dual
  union all select 4, 'void' from dual
  union all select 1, 'void' from dual
  union all select 6, 'void' from dual
  union all select 10, 'void' from dual;  
  dbms_output.put_line('Number of lines affected by previous DML operation:'||sql%rowcount);

  for val in 1..10
    loop
      update client set status = 'updated' where val_cli = val;
      if sql%rowcount = 0 then
        dbms_output.put_line('no client with '||val||' val_cli.');
      elsif sql%rowcount = 1 then
        dbms_output.put_line(sql%rowcount||' client updated for '||val);
      else -- >1
        dbms_output.put_line(sql%rowcount||' clients updated for '||val);
      end if;
  end loop;  
end;

В результате чего:

Value when entering the block:
Number of lines affected by previous DML operation:5
2 clients updated for 1
no client with 2 val_cli.
no client with 3 val_cli.
1 client updated for 4
no client with 5 val_cli.
1 client updated for 6
no client with 7 val_cli.
no client with 8 val_cli.
no client with 9 val_cli.
1 client updated for 10

Примерьте вот это..


create table client (
  val_cli integer
 ,status varchar2(10)
);

---------------------
begin
insert into client
select 1, 'void' from dual
union all
select 4, 'void' from dual
union all
select 1, 'void' from dual
union all
select 6, 'void' from dual
union all
select 10, 'void' from dual;
end;

---------------------
select * from client;

---------------------
declare
  counter integer := 0;
begin
  for val in 1..10
    loop
      update client set status = 'updated' where val_cli = val;
      if sql%rowcount = 0 then
        dbms_output.put_line('no client with '||val||' val_cli.');
      else
        dbms_output.put_line(sql%rowcount||' client updated for '||val);
        counter := counter + sql%rowcount;
      end if;
  end loop;
   dbms_output.put_line('Number of total lines affected update operation: '||counter);
end;

---------------------
select * from client;

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

Результат будет таким, как показано ниже:


2 клиента обновлены для 1
нет клиента с 2 val_cli.
нет клиента с 3 val_cli.
1 клиент обновлен для 4
нет клиента с 5 val_cli.
1 клиент обновлен для 6
нет клиента с 7 val_cli.
нет клиента с 8 val_cli.
нет клиента с 9 val_cli.
1 клиент обновлен для 10
Общее количество строк, затронувших операцию обновления:5


Используйте аналитическую функцию Count (*) по разделу NULL Это будет подсчитать общее количество строк

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top