小编Ben*_*min的帖子

如何在触发器函数中将 NEW.* 传递给 EXECUTE

我有一个简单的任务是将巨大的 MD5 值插入到表(分区表)中,并创建了一个触发器和一个触发器函数来代替INSERT操作。在函数中,我检查了前两个字符NEW.md5以确定应插入哪个表。

DECLARE
  tb text;
BEGIN
  IF TG_OP = 'INSERT' THEN
    tb = 'samples_' || left(NEW.md5, 2);
    EXECUTE(format('INSERT INTO %s VALUES (%s);', tb, NEW.*)); <- WRONG
  END IF;
  RETURN NULL;
END;
Run Code Online (Sandbox Code Playgroud)

问题是如何连接NEW.*到SQL语句中?

postgresql triggers dynamic-sql plpgsql

1
推荐指数
1
解决办法
2817
查看次数

标签 统计

dynamic-sql ×1

plpgsql ×1

postgresql ×1

triggers ×1