我有一个函数,用以下代码检查PostgreSQL数据库中是否存在表:
CREATE OR REPLACE FUNCTION public.sp_table_exists(p_in_table_name character varying)
RETURNS boolean AS
$$
DECLARE QUERY_COUNT INTEGER DEFAULT 1;
QUERY_STRING VARCHAR(300);
BEGIN
QUERY_STRING := CONCAT('SELECT RELNAME FROM PG_CLASS WHERE RELNAME = ''',p_in_table_name,'''');
EXECUTE QUERY_STRING;
GET DIAGNOSTICS QUERY_COUNT = ROW_COUNT;
IF QUERY_COUNT > 0 THEN
RETURN TRUE;
ELSE
RETURN FALSE;
END IF;
END;
$$ LANGUAGE plpgsql;
我试图使用上述函数的输出来赋值给一个布尔值,但是PostgreSQL不允许我这样做。
DECLARE DEBUG_ENABLED boolean DEFAULT FALSE;
DEBUG_ENABLED := PERFORM sp_table_exists('temp_table');
或者
DEBUG_ENABLED := SELECT * FROM sp_table_exists('temp_table');
能否请您帮我解决这个问题?
CREATE FUNCTION
和SELECT INTO
都完美地工作。 - Robins Tharakan