Oracle中dual表的用途

本文介绍了Oracle数据库中DUAL表的独特性质及其用途,包括如何通过DUAL表查询当前用户、系统时间等信息,并探讨了DUAL表的内部运作机制。


标签:oracle 
 


dual是一个虚拟表,用来构成select的语法规则,oracle保证dual里面永远只有一条记录。我们可以用它来做很多事情,如下:


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 your_sequence.nextval from dual;--获得序列your_sequence的下一个值


select your_sequence.currval from dual;--获得序列your_sequence的当前值


4、可以用做计算器


select 7*9 from dual;


------


Oracle系统中dual表是一个“神秘”的表,网上有很多网友都对该表进行了测试,该表只有一行一列,其实该表和系统中的其他表一样,一样可以执行插入、更新、删除操作,还可以执行drop操作。但是不要去执行drop表的操作,否则会使系统不能用,数据库起不了,会报Database startup crashes with ORA-1092错误。


此时也不要慌乱,可以通过执行以下步骤来进行恢复。可以用sys用户登陆。


 


在d:pfile.bak文件中最后加入一条:


 


重新启动数据库:


 


[an error occurred while processing this directive]


 


 


=====


DUAL ? 有什么神秘的? 当你想得到ORACLE系统时间, 简简单单敲一行SQL 不就得了吗? 故弄玄虚…. 

SQL> select sysdate from dual; SYSDATE --------- 28-SEP-03 哈哈, 确实DUAL的使用很方便. 但是大家知道DUAL倒底是什么OBJECT, 它有什么特殊的行为吗? 来,我们一起看一看. 

首先搞清楚DUAL是什么OBJECT : SQL> connect system/manager Connected. SQL> select owner, object_name , object_type from dba_objects where object_name like '%DUAL%'; OWNER OBJECT_NAME OBJECT_TYPE

 --------------- --------------- ------------- 

SYS DUAL TABLE PUBLIC DUAL SYNONYM 原来DUAL是属于SYS schema的一个表,然后以PUBLIC SYNONYM的方式供其他数据库USER使用. 再看看它的结构: SQL> desc dual Name Null? Type

 ----------------------------------------- -------- ---------------------------- 

DUMMY VARCHAR2(1) SQL> 只有一个名字叫DUMMY的字符型COLUMN . 然后查询一下表里的数据: SQL> select dummy from dual; DUMMY

 ---------- 

X 哦, 只有一条记录, DUMMY的值是’X’ .很正常啊,没什么奇怪嘛. 好,下面就有奇妙的东西出现了! 插入一条记录: SQL> connect sys as sysdba Connected. SQL> insert into dual values ( 'Y');

 1 row created.  bitsCN.nET*中国网管博客SQL> commit; Commit complete. SQL> select count(*) from dual; COUNT(*) 

---------- 

2 迄今为止,一切正常. 然而当我们再次查询记录时,奇怪的事情发生了 SQL> select * from dual; DUMMY ---------- X 刚才插入的那条记录并没有显示出来 ! 明明DUAL表中有两条记录, 可就是只显示一条! 再试一下删除 ,狠一点,全删光 ! SQL> delete from dual; /*注意没有限定条件,试图删除全部记录*/ 

1 row deleted. SQL> commit; Commit complete. 哈哈,也只有一条记录被删掉, SQL> select * from dual;  [bitsCN.Com]DUMMY

 ----------

 Y 为什么会这样呢? 难道SQL的语法对DUAL不起作用吗?带着这个疑问, 我查询了一些ORACLE官方的资料. 原来ORACLE对DUAL表的操作做了一些内部处理,尽量保证DUAL表中只返回一条记录.当然这写内部操作是不可见的 . 看来ORACLE真是蕴藏着无穷的奥妙啊! 

附: ORACLE关于DUAL表不同寻常特性的解释 

There is internalized code that makes this happen. Code checks that ensure that a table scan of SYS.DUAL only returns one row. Svrmgrl behaviour is incorrect but this is now an obsolete product. The base issue you should always remember and keep is: DUAL table should always have 1 ROW. Dual is a normal table with one dummy column of varchar2(1). This is basically used from several applications as a pseudo table for getting results from a select statement that use functions like sysdate or other prebuilt or application functions. If DUAL has no rows at all some applications (that use DUAL) may fail with NO_DATA_FOUND exception. If DUAL has more than 1 row then applications (that use DUAL) may fail with TOO_MANY_ROWS exception.

潮汐研究作为海洋科学的关键分支,融合了物理海洋学、地理信息系统及水利工程等多领域知识。TMD2.05.zip是一套基于MATLAB环境开发的潮汐专用分析工具集,为科研人员与工程实践者提供系统化的潮汐建模与计算支持。该工具箱通过模块化设计实现了两大核心功能: 在交互界面设计方面,工具箱构建了图形化操作环境,有效降低了非专业用户的操作门槛。通过预设参数输入模块(涵盖地理坐标、时间序列、测站数据等),用户可自主配置模型运行条件。界面集成数据加载、参数调整、可视化呈现及流程控制等标准化组件,将复杂的数值运算过程转化为可交互的操作流程。 在潮汐预测模块中,工具箱整合了谐波分解法与潮流要素解析法等数学模型。这些算法能够解构潮汐观测数据,识别关键影响要素(包括K1、O1、M2等核心分潮),并生成不同时间尺度的潮汐预报。基于这些模型,研究者可精准推算特定海域的潮位变化周期与振幅特征,为海洋工程建设、港湾规划设计及海洋生态研究提供定量依据。 该工具集在实践中的应用方向包括: - **潮汐动力解析**:通过多站点观测数据比对,揭示区域主导潮汐成分的时空分布规律 - **数值模型构建**:基于历史观测序列建立潮汐动力学模型,实现潮汐现象的数字化重构与预测 - **工程影响量化**:在海岸开发项目中评估人工构筑物对自然潮汐节律的扰动效应 - **极端事件模拟**:建立风暴潮与天文潮耦合模型,提升海洋灾害预警的时空精度 工具箱以"TMD"为主程序包,内含完整的函数库与示例脚本。用户部署后可通过MATLAB平台调用相关模块,参照技术文档完成全流程操作。这套工具集将专业计算能力与人性化操作界面有机结合,形成了从数据输入到成果输出的完整研究链条,显著提升了潮汐研究的工程适用性与科研效率。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值