如何在PostgreSQL中添加列(如果不存在)?

前端之家收集整理的这篇文章主要介绍了如何在PostgreSQL中添加列(如果不存在)?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
问题很简单。如何添加列x到表y,但只有当x列不存在?我发现只有解决方here如何检查列是否存在。
SELECT column_name 
FROM information_schema.columns 
WHERE table_name='x' and column_name='y';
这里是一个简短的版本使用“DO”语句:
DO $$ 
    BEGIN
        BEGIN
            ALTER TABLE <table_name> ADD COLUMN <column_name> <column_type>;
        EXCEPTION
            WHEN duplicate_column THEN RAISE NOTICE 'column <column_name> already exists in <table_name>.';
        END;
    END;
$$

您不能将这些作为参数传递,您需要在客户端的字符串中执行变量替换,但这是一个自包含的查询,只有在列已存在时才发出消息,如果不存在,则添加;将继续在其他错误(如无效的数据类型)上失败。

如果这些方法是来自外部源的随机字符串,我不推荐使用这些方法。不管你使用什么方法(作为查询执行的cleint端或服务器端动态字符串),它将是一个灾难的食谱,因为它打开了sql注入攻击。

猜你在找的Postgre SQL相关文章