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

function – 从记录变量中选择列(PostgreSQL 8.4)

发布时间:2020-12-13 15:59:45 所属栏目:百科 来源:网络整理
导读:我正在尝试从我正在从Update规则调用的函数中的记录变量中选择一列,并且收到以下错误: ‘无法识别记录数据类型中的列“名称” 以下是我正在做的产生错误的方法: 在更新规则中: SELECT * INTO TEMPORARY TABLE TempTable FROM NEW;SELECT MyFunction(); 从
我正在尝试从我正在从Update规则调用的函数中的记录变量中选择一列,并且收到以下错误:

‘无法识别记录数据类型中的列“名称”

以下是我正在做的产生错误的方法:

在更新规则中:

SELECT * INTO TEMPORARY TABLE TempTable FROM NEW;
SELECT MyFunction();

从MyFunction内部()

DECLARE RecordVar Record;
SELECT * INTO STRICT RecordVar FROM TempTable;
EXECUTE 'UPDATE AnotherTable SET column = $1.name' USING RecordVar;

注意:我意识到有更简单的方法来实现上面代码的实现,但我已经简化了实际的实现,专注于我遇到的问题,这已经开辟了其他可能的解决方案,但我真的很想得到上面的代码如果可能的话.

解决方法

我刚想通了.我不是将NEW中的列插入临时表,而是将新记录作为单个列插入临时表,并将其称为RecordVar.我的函数内部为“NEW”.我的规则和功能现在看起来像这样:

在更新规则中:

SELECT NEW AS "NEW" INTO TEMPORARY TABLE TempTable;
SELECT MyFuction();

从MyFunction内部()

DECLARE RecordVar Record;
SELECT * INTO STRICT RecordVar FROM TempTable;
EXECUTE 'UPDATE AnotherTable SET column = $1.name' USING RecordVar."NEW";

(编辑:李大同)

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

    推荐文章
      热点阅读