dual简介

转载 2011年01月10日 15:07:00

这几天一直在研究oracle,常常会用到dual这个系统表,dual表到底是一个什么表?带着疑问google了一下,现在总结一下:

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;--获得一个随机数

3、可以用做计算器
  select 7*9*10-10 from dual;

4、查看系统时间
    
select sysdate from dual;

postgresql中没有dual表解决方案

CREATE OR REPLACE VIEW dual ASSELECT NULL::"unknown"WHERE 1 = 1;ALTER TABLE dual OWNER TO jxdx;GRANT...
  • wangxifeng920
  • wangxifeng920
  • 2011年02月12日 16:55
  • 1189

dual表简介

dual表是Oracle中实际存在一个表,任何用户都可以读取,常用在没有目标表的select语句块中。下面是我总结的一些常用语句的作用:createsequence zlf incrementby1s...
  • Amy8686
  • Amy8686
  • 2010年06月25日 20:08
  • 445

【理论】支持向量机6:Duality —— 关于 dual 问题推导的一些补充理论

原文:http://blog.pluskid.org/?p=702 在之前关于 support vector 的推导中,我们提到了 dual ,这里再来补充一点相关的知识。这套理论不仅适用于 S...
  • zhazhiqiang2010
  • zhazhiqiang2010
  • 2014年02月19日 17:26
  • 2274

oracle中的dual是什么意思?

dual是一个虚拟表,用来构成select的语法规则,oracle保证dual里面永远只有一条记录。我们可以用它来做很多事情,如下: 1、查看当前用户,可以在 SQL Plus中执行下面语句 ...
  • Ideality_hunter
  • Ideality_hunter
  • 2016年11月09日 11:53
  • 3417

Oracle中的dual表到底是什么

dual是一个虚拟表,用来构成select的语法规则,oracle保证dual里面永远只有一条记录。我们可以用它来做很多事情,如下: 1、查看当前用户,可以在 SQL Plus中执行下面语句 sq...
  • huiwenjie168
  • huiwenjie168
  • 2012年02月09日 15:23
  • 2775

例解EIGRP DUAL算法网络收敛原理

EIGRP采用的是DUAL(Diffusing Update Algorithm,扩散更新算法)。这个算法可以确保在极短时间内无环路计算出路由结果,并且允许所有与拓扑改变相关的设备在同一时间进行同步更...
  • lycb_gz
  • lycb_gz
  • 2013年09月22日 08:53
  • 5855

DB2中类似于ORACLE中的DUAL表的表

DB2中类似于ORACLE中的DUAL表的表关键字: db2 DB2中类似于ORACLE中的DUAL表的表问题 在ORACLE中,数据库用户可以通过访问DUAL表获取一些系统信息,例如: 'SELEC...
  • dada360778512
  • dada360778512
  • 2011年01月31日 09:53
  • 6919

【SQL】DUAL

DUAL表是Oracle系统中对所有用户可用的一个实际存在的1行1列的表,这个表不能用来存储信息,在实际应用中仅用来执行SELECT语句。可以使用DUAL表来查询系统的信息。 --dual是1行1列的...
  • NextAction
  • NextAction
  • 2017年03月22日 20:39
  • 460

primal and dual(原问题和对偶问题)

定义: 这是优化界的一种方法,对偶问题为原问题提供了一个霞
  • haimengao
  • haimengao
  • 2014年09月06日 12:21
  • 3897

双显示器任务栏 Dual Monitor Taskbar

双显示器任务栏 Dual Monitor Taskbar
  • gaojier1000
  • gaojier1000
  • 2014年08月25日 15:49
  • 1455
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:dual简介
举报原因:
原因补充:

(最多只允许输入30个字)