使用Postgresql以非超级用户身份创建强制转换

时间:2018-02-28 13:56:05

标签: postgresql function casting

我特别需要在postgresql 9.6中创建一个新的强制转换:

CREATE OR REPLACE FUNCTION boolean_to_float(b boolean) RETURNS float AS $$
SELECT b::int::float;$$ LANGUAGE SQL;
DROP CAST IF EXISTS (boolean as float);
CREATE CAST (boolean AS float) WITH FUNCTION boolean_to_float(boolean) ;

不幸的是,我收到了以下回复:

ERROR:  must be owner of type boolean or type double precision

数据库由我正在使用的用户拥有。是否可以强制DROP/CREATE CAST

1 个答案:

答案 0 :(得分:0)

正如错误消息所示:您必须以用户postgres进行连接才能执行此操作。