返回顶部
首页 > 资讯 > 数据库 >一文掌握Oracle中的Dual系统表
  • 710
分享到

一文掌握Oracle中的Dual系统表

2024-04-02 19:04:59 710人浏览 八月长安
摘要

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

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

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

select * from dual;

一文掌握Oracle中的Dual系统表

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

一文掌握Oracle中的Dual系统表

或者sys用户下【SQL窗口】执行以下语句

SELECT DBMS_METADATA.GET_DDL('TABLE','DUAL') FROM DUAL;

一文掌握Oracle中的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;

一文掌握Oracle中的Dual系统表

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

一文掌握Oracle中的Dual系统表

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

一文掌握Oracle中的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;

一文掌握Oracle中的Dual系统表

一文掌握Oracle中的Dual系统表

  • 获得一个随机数
select DBMS_RANDOM.random from dual;

一文掌握Oracle中的Dual系统表

 

  • Dual到底是什么object?
select owner, object_name , object_type from dba_objects where object_name like '%DUAL%';

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

您可能感兴趣的文档:

--结束END--

本文标题: 一文掌握Oracle中的Dual系统表

本文链接: https://lsjlt.com/news/34311.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作