共计 1579 个字符,预计需要花费 4 分钟才能阅读完成。
这几天一直在研究 Oracle,常常会用到 dual 这个系统表,dual 表到底是一个什么表?带着疑问查了百度了一下,现在总结一下:
DUAL 是 Oracle 与数据字典一起自动创建的一个表,它只有一列:DUMMY,其数据类型为:VARCHAR2(1)。DUAL 中只有一行数据:’X’。DUAL 属于 SYS 模式,但所有用户都可以使用 DUAL 名称访问它。用 SELECT 计算常量表达式、伪列等值时常用该表,因为它只返回一行数据,而使用其它表时可能返回多个数据行。
查看表结构:desc dual;
执行 select * from dual; 里面只有一条记录,插入一条记录,insert into dual values(‘Y’); 后,再次查询 dual 表,里面任然显示一条记录。刚才插入的那条记录并没有显示出来。明明 DUAL 表中有两条记录,可就是只显示一条。再试一下删除,狠一点,全删光,也只有一条记录被删掉。为什么会这样呢? 难道 SQL 的语法对 DUAL 不起作用吗? 带着这个疑问, 我查询了一些 ORACLE 官方的资料. 原来 ORACLE 对 DUAL 表的操作做了一些内部处理, 尽量保证 DUAL 表中只返回一条记录. 当然这写内部操作是不可见的。看来 ORACLE 真是蕴藏着无穷的奥妙啊。
dual 是一个 oracle 内部表,不论我们做什么操作(不要删除记录)它都只有一条记录,上面插入了一条之后,他仍然只有 1 条记录,所以很多取系统时间,计算,等只要选择一条记录,而且记录内容与表内容无关的操作,我们都喜欢使用这个表。虚表(dual)是 oracle 提供的最小的工作表,它仅包含一行一列。对于虚表(dual)来说,其中的列往往是不相关的或无关紧要的。
DUAL?有什么神秘的?当你想得到 ORACLE 系统时间,简简单单敲一行 SQL 不就得了吗?故弄玄虚…
SQL> select sysdate from dual;
确实 DUAL 的使用很方便。但是大家知道 DUAL 倒底是什么 OBJECT,它有什么特殊的行为吗?我们一起看一看。首先搞清楚 DUAL 是什么 OBJECT:
select owner, object_name , object_type from dba_objects where object_name like ‘%DUAL%’;
原来 DUAL 是属于 SYS schema 的一个表, 然后以 PUBLIC SYNONYM 的方式供其他数据库 USER 使用。
1、查看当前用户,可以在 SQL Plus 中执行下面语句
select user from dual;
2、用来调用系统函数
select to_char(SYSDATE,’yyyy-mm-dd hh24:mi:ss’) from dual;– 获得当前系统时间
select sys_context(‘userenv’,’terminal’) from dual;– 获得主机名
select sys_context(‘userenv’,’language’) from dual;– 获得当前 locale
select DBMS_RANDOM.random from dual;– 获得一个随机数
select replace(substr(to_char(sysdate,’yyyy-mm-dd hh24:mi:ss’),0,10),’-‘,’/’) 系统当前时间 from dual;
3、可以用做计算器
select 7*9*10-10 from dual;
4、查看系统时间
select sysdate from dual;
希望可以给大家有帮助,哪里不对 希望大家多多交流。
更多 Oracle 相关信息见 Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12
本文永久更新链接地址 :http://www.linuxidc.com/Linux/2017-01/139582.htm