4

首先,是的,我已经阅读了 DO 语句的文档 :) http://www.postgresql.org/docs/9.1/static/sql-do.html

所以我的问题:

我需要执行一些包含 UPDATE 语句的动态代码块并计算所有受影响的行数。我正在使用Ado.Net提供程序。

在 Oracle 中,解决方案将有 4 个步骤:

  1. 将 InputOutput 参数“N”添加到命令
  2. 添加开始...结束;命令
  3. 在每个语句后添加:N := :N + sql%rowcount 。
  4. 完成!我们可以在执行后从命令中读取 N 参数。

我怎样才能用 PostgreSQL 做到这一点?我正在使用 npgsql 提供程序,但如果有帮助可以迁移到 devard。

4

2 回答 2

9

DO语句块非常适合执行动态 SQL。它们不利于返回值。为此使用plpgsql 函数

您需要的关键语句是:

GET DIAGNOSTICS integer_var = ROW_COUNT;

手册中的详细信息。

示例代码:

CREATE OR REPLACE FUNCTION f_upd_some()
  RETURNS integer AS
$func$
DECLARE
   ct int;
   i  int;
BEGIN
   EXECUTE 'UPDATE tbl1 ...';       -- something dynamic here
   GET DIAGNOSTICS ct = ROW_COUNT;  -- initialize with 1st count

   UPDATE tbl2 ...;                 -- nothing dynamic here 
   GET DIAGNOSTICS i = ROW_COUNT;
   ct := ct + i;                    -- add up

   RETURN ct;
END
$func$  LANGUAGE plpgsql;

称呼:

SELECT * FROM f_upd_some();
于 2012-04-16T13:32:49.490 回答
1

我的解决方案很简单。在 Oracle 中,我需要使用变量来计算更新行的总和,因为command.ExecuteNonQuery()仅返回受批处理中最后一次 UPDATE 影响的行数。

但是,npgsql返回由所有 UPDATE 查询更新的所有行的总和。所以我只需要调用command.ExecuteNonQuery()并得到没有任何变量的结果。比使用 Oracle 容易得多。

于 2012-04-17T12:18:31.600 回答