oracle 存储过程将表名和字段名变为大写(报错ORA-20000)

本文提供了一种在Oracle数据库中将表名和字段名统一转换为大写的解决方案,包括基础查询脚本和存储过程,以实现批量修改。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、表名大写:

基础查询脚本: SELECT ‘ALTER TABLE "’||TABLE_NAME||’" rename to '||UPPER(TABLE_NAME) FROM USER_TABLES;

过程:
—修改表名
DECLARE
SQLR_ALTER VARCHAR2(200);
BEGIN
FOR C IN(SELECT ‘ALTER TABLE "’ || TABLE_NAME || '" RENAME TO ’ ||
UPPER(TABLE_NAME) AS SQLR FROM USER_TABLES) LOOP
BEGIN
SQLR_ALTER := C.SQLR;
EXECUTE IMMEDIATE SQLR_ALTER;
EXCEPTION
WHEN
OTHERS THEN DBMS_OUTPUT.PUT_LINE(SQLR_ALTER || ‘发生错误,程序继续’);
CONTINUE;
END;
END LOOP;
END;
/

2、字段名大写

基础查询脚本:SELECT ‘ALTER TABLE ‘||TABLE_NAME||’ rename column "’||COLUMN_NAME||’" TO’ || UPPER(COLUMN_NAME) AS SQLR FROM USER_TAB_COLUMNS;

过程:
—修改列名
DECLARE
SQLR_ALTER VARCHAR2(200);
BEGIN
DBMS_OUTPUT.ENABLE (buffer_size=>null); – 表示没有限制
FOR C IN (SELECT
‘ALTER TABLE ‘||TABLE_NAME||’ rename column "’||COLUMN_NAME||’" to '||UPPER(COLUMN_NAME) AS SQLR
FROM USER_TAB_COLUMNS) LOOP
BEGIN
SQLR_ALTER := C.SQLR;
EXECUTE IMMEDIATE SQLR_ALTER;
EXCEPTION
WHEN
OTHERS THEN DBMS_OUTPUT.PUT_LINE(SQLR_ALTER||‘发生错误,程序继续’);
CONTINUE;
END;
END LOOP;
END;
/

注:本地执行列名修改时,会报ORA-20000的错误
在这里插入图片描述

报错原因: 在OUTPUT输出时,通过DBMS_OUTPUT.ENABLE控制输出结果的缓冲大小,而buffer size默认大小是20000,每行最大限制是32k。当我们使用游标输出时,如果结果很多,将会超过这个值报ORA-20000错误:ORU-10027: buffer overflow, limit of 10000 bytes.
解决方法:
在存储过程begin后面加 : DBMS_OUTPUT.ENABLE (buffer_size=>null)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值