zoukankan      html  css  js  c++  java
  • 【Oracle】表名/列名,大/小写转换

    1、表名,小写转大写。如下:my_test转换MY_TEST

    DECLARE
        v_tablename_x VARCHAR2(20);
        v_tablename_d VARCHAR2(20);
    begin
        v_tablename_x:='my_test';
        v_tablename_d:='MY_TEST';
        execute immediate 'alter table "'||v_tablename_x||'" rename to '||v_tablename_d||'';
    exception
        when others then
        dbms_output.put_line(v_tablename_d||'已存在');
    end;

    2、列名,小写转大写

    DECLARE
        v_tablename_d VARCHAR2(20);
    
    begin
        v_tablename_d:='MY_TEST';
        for c in (select COLUMN_NAME cn from all_tab_columns where table_name=v_tablename_d) loop
        begin
            execute immediate 'alter table "'||v_tablename_d||'" rename column "'||c.cn||'" to '||c.cn;
            exception
            when others then
            dbms_output.put_line(v_tablename_d||'.'||c.cn||'已经存在');
        end;
        end loop;
    end;

    3、表和列一起,小写转大写

    DECLARE
        v_tablename_x VARCHAR2(20);
        v_tablename_d VARCHAR2(20);
    
    begin
        v_tablename_x:='my_test';
        v_tablename_d:='MY_TEST';
        for c in (select COLUMN_NAME cn from all_tab_columns where table_name=v_tablename_x) loop
        begin
            execute immediate 'alter table "'||v_tablename_x||'" rename column "'||c.cn||'" to '||c.cn;
            exception
            when others then
            dbms_output.put_line(v_tablename_x||'.'||c.cn||'已经存在');
        end;
        end loop;
    
        execute immediate 'alter table "'||v_tablename_x||'" rename to '||v_tablename_d||'';
        exception
        when others then
        dbms_output.put_line(v_tablename_d||'已存在');
    end;

    4、表和列一起,大写转小写

    DECLARE
        v_tablename_x VARCHAR2(20);
        v_tablename_d VARCHAR2(20);
    
    begin
        v_tablename_x:='my_test';
        v_tablename_d:='MY_TEST';
    
        for c in (select COLUMN_NAME cn from all_tab_columns where table_name=v_tablename_d) loop
            begin
                execute immediate 'alter table '||v_tablename_d||' rename column '||c.cn||' to "'||LOWER(c.cn)||'"';
                exception
                when others then
                dbms_output.put_line(v_tablename_d||'.'||c.cn||'已经存在');
            end;
        end loop;
    
        execute immediate 'alter table '||v_tablename_d||' rename to "'||v_tablename_x||'"';
        exception
        when others then
        dbms_output.put_line(v_tablename_x||'已存在');
    end;

    5、列名,大写转小写

    DECLARE
        v_tablename_d VARCHAR2(20);
    
    begin
        v_tablename_d:='MY_TEST';
    
        for c in (select COLUMN_NAME cn from all_tab_columns where table_name=v_tablename_d) loop
            begin
                execute immediate 'alter table '||v_tablename_d||' rename column '||c.cn||' to "'||LOWER(c.cn)||'"';
                exception
                when others then
                dbms_output.put_line(v_tablename_d||'.'||c.cn||'已经存在');
            end;
        end loop;
    end;

    6、表名,大写转小写

    DECLARE
        v_tablename_x VARCHAR2(20);
        v_tablename_d VARCHAR2(20);
    
    begin
        v_tablename_x:='my_test';
        v_tablename_d:='MY_TEST';
    
        execute immediate 'alter table '||v_tablename_d||' rename to "'||v_tablename_x||'"';
        exception
        when others then
        dbms_output.put_line(v_tablename_x||'已存在');
    end;
  • 相关阅读:
    每天OnLineJudge 之 “蛇形矩阵 ”
    Hello World 发生了什么?
    软件开发人员真的了解SQL索引吗(索引使用原则)
    软件开发人员真的了解SQL索引吗(聚集索引)
    项目经验总结(一)如何约定接口的定义
    min的个人网站终于创建起来了
    WCF单例服务,如何实现并发
    如何规范.net中的js开发(2)原理篇(更新版)
    网站架构之缓存应用(3)实现篇
    网站架构之缓存应用(1)概念篇
  • 原文地址:https://www.cnblogs.com/xiaostudy/p/14240256.html
Copyright © 2011-2022 走看看