壹佰网|ERP100 - 企业信息化知识门户

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4962|回复: 0

[其他] dual表的用途

[复制链接]
发表于 2011/11/18 10:39:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。如果您注册时有任何问题请联系客服QQ: 83569622  。

您需要 登录 才可以下载或查看,没有帐号?注册

x
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用户登陆。
  SQL> create pfile=’d:pfile.bak’ from spfile
  SQL> shutdown immediate
  在d:pfile.bak文件中最后加入一条:
  replication_dependency_tracking = FALSE
  重新启动数据库:
  SQL> startup pfile=’d:pfile.bak’
  SQL> create table “sys”.”DUAL”
  [an error occurred while processing this directive]
  =====
  DUAL ? 有什么神秘的? 当你想得到Oracle系统时间, 简简单单敲一行SQL 不就得了吗? 故弄玄虚….
  SQL> select sysdate from dual;
  SYSDATE
  ---------
  28-SEP-03
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|小黑屋|手机版|壹佰网 ERP100 ( 京ICP备19053597号-2 )

Copyright © 2005-2012 北京海之大网络技术有限责任公司 服务器托管由互联互通
手机:13911575376
网站技术点击发送消息给对方83569622   广告&合作 点击发送消息给对方27675401   点击发送消息给对方634043306   咨询及人才点击发送消息给对方138011526

GMT+8, 2025/11/29 07:13 , Processed in 0.012905 second(s), 14 queries , File On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表