暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Dual Dual Dual

SQL数据库运维 2022-06-23
372

点击蓝色字关注“SQL数据库运维”

这几天一直在研究Oracle,常常会用到Dual这个系统表,Dual表到底是一个什么表?带着疑问baidu了一下:

Dual表是Oracle提供的最小的工作表(其实是一种虚拟表),是sys用户下的一张内部表,只有一行一列(一列:DUMMY,一列:DUMMY,其数据类型为:VARCHAR2(1)。所有用户都可以使用Dual名称访问,无论什么时候这个表总是存在。不论进行何种操作(不要删除记录),它都只有一条记录——'X'。

    select * from dual;


    我们来查一下它的表结构,PL/SQL Developer【命令窗口】输入desc dual;

    或者sys用户下【SQL窗口】执行以下语句
      SELECT DBMS_METADATA.GET_DDL('TABLE','DUAL') FROM DUAL;


      那么Dual在实际应用过程中可以做些什么呢?
      • Dual表主要用来选择系统变量或求一个表达式的值,最常见的一个简单例子,执行一个查看当前日期的语句,这条语放在任何一个Oracle数据库当中都不会报错,所以一般做一些特定查询的时候用这个表是最稳妥的。
        select sysdate from dual;
        --或日期转换获得当前系统时间,‘分钟’ 要用mi;hh24表示24小时制,hh表示12小时制。
        select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual;


        • 当计算器使用
          select 1024*1024 from dual;


          • 查询当前连接用户
            select user from dual;


            • 查看序列值

              --创建序列aaa 以1开始,每次加1
              create sequence aaa increment by 1 start with 1;
              --获得序列aaa 的下一个序列值,每次查询加1
              select aaa.nextval from dual;
              --获得序列aaa 的当前序列值
              select aaa.currval from dual;


              • 获得一个随机数

                select DBMS_RANDOM.random from dual;



                Dual到底是什么object?

                  select owner, object_name , object_type from dba_objects where object_name like '%DUAL%';

                  经过查询输出的结果可以看到Dual是属于sys的一个表,然后以PUBLIC SYNONYM的方式供其他用户使用。

                  点击关注“SQL数据库运维”,后台或浏览至公众号文章底部点击“发消息”回复关键字:进群,带你进入高手如云的技术交流群。后台回复关键字:SQL,获取学习资料。

                  动动小手点击加关注呦☟☟☟

                  文章转载自SQL数据库运维,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

                  评论