我正在尝试从我正在从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";
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。