云服务器网:购买云服务器和VPS必上的网站!

一文掌握Oracle中的Dual系统表

这几天一直在研究Oracle,常常会用到Dual这个系统表,Dual表究竟是一个甚么表?带着疑问baidu了一下:
Dual表是Oracle提供的最小的工作表(实际上是一种虚拟表),是sys用户下的一张内部表,只有一行一列(一列:DUMMY,一列:DUMMY,

这几天一直在研究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的方式供其他用户使用。

本文来源:https://www.yuntue.com/post/150522.html | 云服务器网,转载请注明出处!

关于作者: yuntue

云服务器(www.yuntue.com)是一家专门做阿里云服务器代金券、腾讯云服务器优惠券的网站,这里你可以找到阿里云服务器腾讯云服务器等国内主流云服务器优惠价格,以及海外云服务器、vps主机等优惠信息,我们会为你提供性价比最高的云服务器和域名、数据库、CDN、免费邮箱等企业常用互联网资源。

为您推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注