了解Oracle中的Dual系统表

打印 上一主题 下一主题

主题 1031|帖子 1031|积分 3093

首发微信公众号:SQL数据库运维
原文链接:https://mp.weixin.qq.com/s?__biz=MzI1NTQyNzg3MQ==&mid=2247485212&idx=1&sn=450e9e94fa709b5eeff0de371c62072b&chksm=ea37536cdd40da7a94e165ce4b4c6e70fb1360d51bed4b3566eee438b587fa231315d0a5a5b3&token=1491694448&lang=zh_CN#rd
 
这几天一直在研究Oracle,常常会用到Dual这个系统表,Dual表到底是一个什么表?带着疑问baidu了一下:
Dual表是Oracle提供的最小的工作表(其实是一种虚拟表),是sys用户下的一张内部表,只有一行一列(一列:DUMMY,一列:DUMMY,其数据类型为:VARCHAR2(1))。所有用户都可以使用Dual名称访问,无论什么时候这个表总是存在。不论进行何种操作(不要删除记录),它都只有一条记录——'X'。
  1. select * from dual;
复制代码

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

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

 
那么Dual在实际应用过程中可以做些什么呢?

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

  • 查询当前连接用户
    1. select user from dual;
    复制代码

  • 查看序列值
    1. --创建序列aaa 以1开始,每次加1
    2. create sequence aaa increment by 1 start with 1;
    3. --获得序列aaa 的下一个序列值,每次查询加1
    4. select aaa.nextval from dual;
    5. --获得序列aaa 的当前序列值
    6. select aaa.currval from dual;
    复制代码


  •  获得一个随机数
    1. select DBMS_RANDOM.random from dual;
    复制代码

     
     Dual到底是什么object?
    1. select owner, object_name , object_type from dba_objects where object_name like '%DUAL%';
    复制代码
    经过查询输出的结果可以看到Dual是属于sys的一个表,然后以PUBLIC SYNONYM的方式供其他用户使用。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

乌市泽哥

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表