加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-13 15:53:35 所属栏目:百科 来源:网络整理
导读:下面是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
下面是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)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读