DO $$DECLARE r record; i int; v_schema text[] := '{public}'; v_new_owner varchar := 'yysg';BEGIN FOR r IN SELECT 'ALTER TABLE "' || table_schema || '"."' || table_name || '" OWNER TO ' || v_new_owner || ';' AS a FROM information_schema.tables WHERE table_schema = ANY (v_schema) UNION ALL SELECT 'ALTER TABLE "' || sequence_schema || '"."' || sequence_name || '" OWNER TO ' || v_new_owner || ';' AS a FROM information_schema.sequences WHERE sequence_schema = ANY (v_schema) UNION ALL SELECT 'ALTER TABLE "' || table_schema || '"."' || table_name || '" OWNER TO ' || v_new_owner || ';' AS a FROM information_schema.views WHERE table_schema = ANY (v_schema) UNION ALL SELECT 'ALTER FUNCTION "' || nsp.nspname || '"."' || p.proname || '"(' || pg_get_function_identity_arguments(p.oid) || ') OWNER TO ' || v_new_owner || ';' AS a FROM pg_proc p JOIN pg_namespace nsp ON p.pronamespace = nsp.oid WHERE nsp.nspname = ANY (v_schema) UNION ALL SELECT 'ALTER DATABASE "' || current_database() || '" OWNER TO ' || v_new_owner LOOP EXECUTE r.a; END LOOP; FOR i IN array_lower(v_schema, 1)..array_upper(v_schema, 1) LOOP EXECUTE 'ALTER SCHEMA "' || v_schema[i] || '" OWNER TO ' || v_new_owner; END LOOP;END$$;
PGSQL 修改整个schema所有表owner
转载文章标签 PGSQL 修改整个schema所有表o 文章分类 数据库

提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
PostgreSQL教程
PostgreSQL教程
PostgreSQL 数据库 运算符 -
PostgreSQL全面剖析
PostgreSQL全面剖析
PostgreSQL全面剖析 -
PostgreSQL 导出导入表中指定查询数据
PostgreSQL利用临时表导入导出指定查询数据
PostgreSQL 临时表 copy数据导入导出 -
postgreSQL 导出数据、导入
postgreSQL 导出 5G 单表。导入、指定字段导入。
postgre sql postgresql 数据库 shell -
POSTGRESQL能导入DMP
--如何在oracle中导入dmp数据库文件? 2006/2/16 zhanghua first create &
POSTGRESQL能导入DMP 数据库 操作系统 java 导入导出