一文掌握Oracle中的Dual系统表

2022-12-08 0 626

这几天一直在研究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开始,每次加1create sequence aaa increment by 1 start with 1; –获得序列aaa 的下一个序列值,每次查询加1select 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的方式供其他用户使用。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

悠久资源 oracle数据库 一文掌握Oracle中的Dual系统表 https://www.u-9.cn/sql/oracle/6079.html

常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务

  • 0 +

    访问总数

  • 0 +

    会员总数

  • 0 +

    文章总数

  • 0 +

    今日发布

  • 0 +

    本周发布

  • 0 +

    运行天数

注册会员,众多资源免费下载