高斯数据库[GaussDB]TPDSS下面执行批量脚本报错。

文章目录

    • 概要
    • [错误代码:[0]SQL错误码: = 42601 [x.x.x.x:62503/x.x.x.x:8123] ERROR: cannot insert multiple commands into a prepared statement](#错误代码:[0]SQL错误码: = 42601 [x.x.x.x:62503/x.x.x.x:8123] ERROR: cannot insert multiple commands into a prepared statement)
    • [PostgreSQL 对表添加字段](#PostgreSQL 对表添加字段)
    • 小结

概要

在TPDSS下面执行脚本的时候,发现报错,错误码是:42601,说是在预编译的环境下,尝试将一个包含多个SQL命令的字符串作为预编译语句执行时失败了。

错误代码:[0]SQL错误码: = 42601 [x.x.x.x:62503/x.x.x.x:8123] ERROR: cannot insert multiple commands into a prepared statement

这么神奇的报错,最后居然是"/"给了结啦。

  • 报错示例:
sql 复制代码
--相关上传文件的表结构调整
---KISC_IMG_BIZ_COMPARE 影像内容检测
---增加对象存储名
do $$
declare   
  table_name1 varchar := 'kisc_img_biz_compare';  
  column_name1 varchar := 'object_storage_id';   
  exists_check boolean;  
begin   
  -- 检查列是否存在  
  select exists (select 1 from information_schema.columns where table_name = table_name1 and column_name = column_name1) into exists_check;
  -- 如果列不存在,则添加列  
  if not exists_check then  
    execute 'alter table ' || table_name1 || '  add column ' || column_name1 || ' varchar(1024) null';   
  end if;  
end $$;

---增加对象存储桶
do $$
declare   
  table_name1 varchar := 'kisc_img_biz_compare';  
  column_name1 varchar := 'object_storage_policy';   
  exists_check boolean;  
begin   
  -- 检查列是否存在  
  select exists (select 1 from information_schema.columns where table_name = table_name1 and column_name = column_name1) into exists_check;
  -- 如果列不存在,则添加列  
  if not exists_check then  
    execute 'alter table ' || table_name1 || '  add column ' || column_name1 || ' varchar(128) null';   
  end if;  
end $$;
  • 正确示例
sql 复制代码
--相关上传文件的表结构调整
---KISC_IMG_BIZ_COMPARE 影像内容检测
---增加对象存储名
do $$
declare   
  table_name1 varchar := 'kisc_img_biz_compare';  
  column_name1 varchar := 'object_storage_id';   
  exists_check boolean;  
begin   
  -- 检查列是否存在  
  select exists (select 1 from information_schema.columns where table_name = table_name1 and column_name = column_name1) into exists_check;
  -- 如果列不存在,则添加列  
  if not exists_check then  
    execute 'alter table ' || table_name1 || 'add column' || column_name1 || ' varchar(1024) null';   
  end if;  
end $$;
/

---增加对象存储桶
do $$
declare   
  table_name1 varchar := 'kisc_img_biz_compare';  
  column_name1 varchar := 'object_storage_policy';   
  exists_check boolean;  
begin   
  -- 检查列是否存在  
  select exists (select 1 from information_schema.columns where table_name = table_name1 and column_name = column_name1) into exists_check;
  -- 如果列不存在,则添加列  
  if not exists_check then  
    execute 'alter table ' || table_name1 || 'add column' || column_name1 || ' varchar(128) null';   
  end if;  
end $$;
/

PostgreSQL 对表添加字段

直接上案例,不废话。

  • 示例1:
sql 复制代码
do $$
declare   
  table_name1 varchar := 'kisc_img_biz_compare';  
  column_name1 varchar := 'object_storage_id';   
  exists_check boolean;  
begin   
  -- 检查列是否存在  
  select exists (select 1 from information_schema.columns where table_name = table_name1 and column_name = column_name1) into exists_check;
  -- 如果列不存在,则添加列  
  if not exists_check then  
    execute 'alter table ' || table_name1 || '  add column ' || column_name1 || ' varchar(1024) null';   
  end if;  
end $$;
  • 示例2:
sql 复制代码
CREATE OR REPLACE FUNCTION add_column_if_not_exists(tablename text, columnname text, columntype text)  
RETURNS void AS 
$$
  
DECLARE  
    col_exists boolean;  
BEGIN  
    -- 检查字段是否已存在  
    SELECT EXISTS (  
        SELECT 1  
        FROM INFORMATION_SCHEMA.COLUMNS  
        WHERE TABLE_NAME = tablename  
          AND COLUMN_NAME = columnname  
    ) INTO col_exists;  
  
    -- 如果字段不存在,则添加字段  
    IF NOT col_exists THEN  
        EXECUTE format('ALTER TABLE %I ADD COLUMN %I %s', tablename, columnname, columntype);  
        RAISE NOTICE 'Column % added to table %.', columnname, tablename;  
    ELSE  
        RAISE NOTICE 'Column % already exists in table %.', columnname, tablename;  
    END IF;  
EXCEPTION  
    WHEN OTHERS THEN  
        RAISE EXCEPTION 'An error occurred while adding column % to table %: %', columnname, tablename, SQLERRM;  
END;  

$$
 LANGUAGE plpgsql;

--调用
SELECT add_column_if_not_exists('my_table', 'new_column', 'varchar(100)');

小结

今天就总结到这里了,后面有更新再写。

相关推荐
懒铭心4 分钟前
Oracle 19c 备份与恢复
oracle
YaBingSec9 分钟前
玄机网络安全靶场:Hadoop YARN ResourceManager 未授权 RCE WP
大数据·数据库·hadoop·redis·笔记·分布式·web安全
m0_635647489 分钟前
Qt打包含有第三方库的软件为应用程序——CQtDeployer
开发语言·数据库·qt
Aloudata14 分钟前
如何通过 NoETL 指标平台构建企业唯一指标计算中心
大数据·数据库·数据分析·指标平台
qq_40999093?15 分钟前
NoSQL数据库解析:Redis
数据库·redis·nosql
小碗羊肉16 分钟前
【MySQL | 第五篇】事务
数据库·mysql
dFObBIMmai17 分钟前
Python Celery任务队列怎么配_实现Web后台异步任务调度处理
jvm·数据库·python
于歌85219 分钟前
Oracle批处理操作方法
数据库·oracle
日取其半万世不竭20 分钟前
PostgreSQL 云服务器安装配置指南:从零开始搭建生产数据库
服务器·数据库·postgresql
@小柯555m22 分钟前
MySql(高级操作符--高级操作符练习(1))
数据库·sql·mysql