参数值被视为数据类型-PL / pgSQL

时间:2019-05-31 20:14:20

标签: function plpgsql

我是使用PL / pgSQL的新手。在过去的三年中,我一直是一名SQL Server开发人员。我正在尝试使用动态SQL编写一个函数,以传入表名,然后传递一个值,然后将该表名退出。

我仍在尝试找出如何在PostgreSQL中编写存储的proc和函数的方法,但是我找不到任何文档来做到这一点。

CREATE OR REPLACE FUNCTION exc_tables (tname VARCHAR)
RETURNS TABLE (module_id bigint, tablename varchar) AS $$
BEGIN
  RETURN QUERY EXECUTE format('SELECT DISTINCT module_id, '||CAST(tname AS varchar)||' as tablename FROM ' || tname || ' WHERE module_ID <> 6');

END;
$$
LANGUAGE plpgsql;

SQL Error [42804]: ERROR: structure of query does not match function result type
  Detail: Returned type dt_conn_type does not match expected type character varying in column 2.
  Where: PL/pgSQL function exc_tables(character varying) line 3 at RETURN QUERY

1 个答案:

答案 0 :(得分:0)

您需要将cast()放入查询中。

...
RETURN QUERY EXECUTE format('SELECT DISTINCT module_id, CAST('''||tname||''' AS varchar) as tablename FROM ' || tname || ' WHERE module_ID <> 6');
...

但是由于它已经是varchar,所以转换是无用的,您可以使用:

RETURN QUERY EXECUTE format('SELECT DISTINCT module_id, '''||tname||''' as tablename FROM ' || tname || ' WHERE module_ID <> 6');

但是您需要确保在查询中将其括在单引号中,以使其成为字符串文字,否则,它意味着整个记录(此时的类型为tname,因此不是{ {1}}。

顺便说一句,使用varchar仅使用一个无占位符的格式字符串,并且没有替换参数也是非常无用的。