Pgsql中如何进行循环遍历与执行传递进行的变量

该文章展示了一段在PostgreSQL中进行批量表数据注释的PL/pgSQL代码。代码通过循环遍历table_1获取nspname,relname和table_name,然后执行COMMENTONTABLE命令。同时,代码包含异常处理机制,如invalid_schema_name,undefined_table和undefined_column错误。
摘要由CSDN通过智能技术生成

背景

     我需要对表数据进行批量注释。示例代码如下:

do
$$
    declare       -- 声明变量
        i record;
    BEGIN
        for i in select nspname,relname,table_name  -- 循环遍历
                   from table_1
            loop
                -- 执行表名的焊接
                raise notice '%',format('comment on table %I.%I is %L;', i.nspname,i.relname,i.table_name);
                EXECUTE format('comment on table %I.%I is %L;', i.nspname,i.relname,i.table_name);
            end loop;
            EXCEPTION WHEN invalid_schema_name THEN raise notice 'nspname的信息填写错误';
                      WHEN undefined_table     THEN raise notice 'relname的信息填写错误';
                      WHEN undefined_column    THEN raise notice 'attname的信息填写错误';
    end;
$$;

提示:异常捕抓错误,需要指定是什么错误,与python有一点不一样,具体的错误代码可以参考链接:Postgresql错误代码:错误编号对应的错误信息

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

数据闲逛人

谢谢大嘎喔~ 开心就好

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值