微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

问题在PostgreSQL中创建函数时“ERROR:语法错误在或附近”ROWTYPE“”

下面是PL / sql中的一个简单过程

PROCEDURE emp_get_rec (emp_rec IN OUT NOcopY emp_content%rOWTYPE)
  IS
    v_cnt   NUMBER;
  BEGIN
    SELECT COUNT(*)
    INTO v_cnt
    FROM emp_content
    WHERE emp_id = emp_rec.emp_id;
    IF v_cnt = 1
    THEN
      SELECT * INTO emp_rec
      FROM emp_content
      WHERE emp_id = emp_rec.emp_id;
    END IF;
 END emp_get_rec;

我试图在Postgresql中转换,

Create or replace function emp_get_rec (emp_rec IN OUT emp_content%rOWTYPE)
AS $BODY$
DECLARE
    v_cnt   NUMBER;
BEGIN

       SELECT COUNT(*)
    INTO v_cnt
    FROM emp_content
    WHERE emp_id = emp_rec.emp_id;
    IF v_cnt = 1
    THEN
      SELECT * INTO emp_rec
      FROM emp_content
      WHERE emp_id = emp_rec.emp_id;
    END IF;
 END;
$BODY$LANGUAGE 'plpgsql';

我正面临以下错误

ERROR: Syntax error at or near “ROWTYPE”

解决方法

Documentation says

Whenever you create a table,a composite type is also automatically created,with the same name as the table,to represent the table’s row type.

因此,您可以使用表名作为类型名称,在语法上它表示类型:

create or replace function emp_get_rec (emp_rec IN OUT emp_content)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐