我是使用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
答案 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
仅使用一个无占位符的格式字符串,并且没有替换参数也是非常无用的。