首页 > 数据库 > mysql教程 > 如何使用'IF NOT EXISTS”在 PostgreSQL 中创建表?

如何使用'IF NOT EXISTS”在 PostgreSQL 中创建表?

Barbara Streisand
发布: 2025-01-04 09:43:40
原创
409 人浏览过

How to Create Tables in PostgreSQL Using

如何使用 PostgreSQL 的“IF NOT EXISTS”子句创建表

MySQL 允许用户使用“IF NOT EXISTS”子句创建表,确保仅在表尚不存在时才创建该表。如果脚本多次运行,这可以防止出现错误。

在 PostgreSQL 中,此功能是在版本 9.1 中引入的,允许使用:

CREATE TABLE IF NOT EXISTS myschema.mytable (i integer);
登录后复制

对于 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$;
登录后复制

可以根据需要经常调用此函数使用:

SELECT create_mytable();
登录后复制

注释:

  • pg_tables 中的 schemaname 和 tablename 列区分大小写。
  • pg_tables 仅包含实际的表,因此标识符可能仍被相关对象占用。
  • 如果用户执行该函数没有创建表所需的权限,该函数可以使用 SECURITY DEFINER 属性。

以上是如何使用'IF NOT EXISTS”在 PostgreSQL 中创建表?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板