首页 >数据库 >mysql教程 >如何在 PostgreSQL 中创建尚不存在的表?

如何在 PostgreSQL 中创建尚不存在的表?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-30 15:02:10387浏览

How to Create a Table in PostgreSQL Only If It Doesn't Already Exist?

在 PostgreSQL 中使用“CREATE TABLE IF NOT EXISTS”创建表

仅当表尚不存在时才创建表的能力是一个有用的功能,可确保表仅创建一次,即使脚本运行多次

在 MySQL 中,可以使用以下语句实现此功能:

CREATE TABLE IF NOT EXISTS foo ...;

PostgreSQL

在 PostgreSQL 9.1 及更高版本中, “如果不存在则创建表”语法是支持:

CREATE TABLE IF NOT EXISTS myschema.mytable (i integer);

旧版本的解决方法

对于 9.1 之前的 PostgreSQL 版本,可以使用函数来实现相同的功能:

CREATE OR REPLACE FUNCTION create_mytable()
  RETURNS void
  LANGUAGE plpgsql AS
$func$
BEGIN
   IF EXISTS (SELECT FROM pg_catalog.pg_tables 
              WHERE  schemaname = 'myschema'
              AND    tablename  = 'mytable') THEN
      RAISE NOTICE 'Table myschema.mytable already exists.';
   ELSE
      CREATE TABLE myschema.mytable (i integer);
   END IF;
END
$func$;

只有在没有创建表的情况下才可以多次调用该函数来创建表

注释:

  • 函数 create_mytable() 假设该表将在 myschema 模式中创建。
  • 如果执行此函数的用户没有创建表所需的权限,可能需要使用 SECURITY DEFINER 属性来确保成功执行。

以上是如何在 PostgreSQL 中创建尚不存在的表?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn