一文掌握Oracle中的Dual系统表

 更新时间:2022年09月30日 11:27:56   作者:蓝涩街灯  
Dual表是Oracle提供的最小的工作表(其实是一种虚拟表),是sys用户下的一张内部表,只有一行一列(一列:DUMMY,一列:DUMMY,其数据类型为:VARCHAR2(1)),接下来通过本文给大家分享Oracle中的Dual系统表,需要的朋友可以参考下

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

您可能感兴趣的文章:

相关文章

  • Oracle 中Contains 函数的用法

    Oracle 中Contains 函数的用法

    这篇文章主要介绍了Oracle 中Contains 函数的用法,查询地址在某个城市的学生,sql语句给大家介绍的非常详细,需要的朋友可以参考下
    2017-11-11
  • Oracle中锁(lock)的用法

    Oracle中锁(lock)的用法

    这篇文章介绍了Oracle中锁(lock)的用法 ,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • Oracle表分区详解

    Oracle表分区详解

    本文详细讲解了Oracle表分区的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • oracle数据库导出和oracle导入数据的二种方法(oracle导入导出数据)

    oracle数据库导出和oracle导入数据的二种方法(oracle导入导出数据)

    这篇文章主要介绍了oracle导入导出数据的二种方法,利用PL/SQL Developer工具导出和利用cmd的操作命令导出的出方法,大家参考使用吧
    2014-01-01
  • oracle 删除重复数据

    oracle 删除重复数据

    我们可能会出现这种情况,表里面的数据重复,那么,如何对重复的数据进行删除呢?
    2009-07-07
  • Oracle 数据仓库ETL技术之多表插入语句的示例详解

    Oracle 数据仓库ETL技术之多表插入语句的示例详解

    Oracle 数据库为 ETL 流程提供了丰富的功能,今天我们就给大家介绍一下 Oracle 多表插入语句,也就是 INSERT ALL 语句,今天通过示例代码给大家介绍Oracle 数据仓库 ETL 技术之多表插入语句的相关知识,感兴趣的朋友一起看看吧
    2021-04-04
  • Oracle数据库中ora-12899错误的解决方法

    Oracle数据库中ora-12899错误的解决方法

    大家在使用oracle数据库时,经常会遇到各种各样的问题,其中ORA-12899就是前段时间我在将数据导入到我本地机器上的时候一直出现的问题.经过一番倒腾问题顺利解决,下面小编把实现思路分享到脚本之家平台大家可以参考下
    2017-11-11
  • sql in查询元素超过1000条的解决方案

    sql in查询元素超过1000条的解决方案

    在oracle数据库中sql使用in时,如果in的能数超过1000就会出问题,下面这篇文章主要给大家介绍了关于sql in查询元素超过1000条的解决方案,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-03-03
  • Oracle中的常用函数详解

    Oracle中的常用函数详解

    本文详细讲解了Oracle中的常用函数,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • Oracle数据远程连接的四种设置方法和注意事项

    Oracle数据远程连接的四种设置方法和注意事项

    Oracle数据库的远程连接可以通过多种方式来实现,本文我们主要介绍四种远程连接的方法和注意事项,并通过示例来说明,接下来我们就开始介绍
    2014-04-04

最新评论