zoukankan      html  css  js  c++  java
  • dual表

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

    1、查看当前用户

    1 SQL> select user from dual;
    2 USER
    3 ------------------------------
    4 SYSTEM

    2、用来调用系统函数

    复制代码
     1 --获得当前系统时间
     2 select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual;
     3 
     4 --获得主机名
     5 select SYS_CONTEXT('USERENV','TERMINAL') from dual;
     6 
     7 --获得当前locale
     8 select SYS_CONTEXT('USERENV','language') from dual;
     9 
    10 --获得一个随机数
    11 select dbms_random.random from dual;
    复制代码

    3、可以用做计算器

    1 SQL> select 1+2 from dual;
    2 1+2
    3 ----------
    4 3

    4、查看序列值

    复制代码
     1 SQL> create sequence aaa increment by 1 start with 1;
     2 SQL> select aaa.nextval from dual;
     3 NEXTVAL
     4 ----------
     5 1
     6 
     7 SQL> select aaa.currval from dual;
     8 CURRVAL
     9 ----------
    10 1
    复制代码

    彩蛋:

    1. 查询Dual是什么Object?

    1 SQL> connect system/manager
    2 Connected.
    3 
    4 SQL> select owner, object_name , object_type from dba_objects where object_name like '%DUAL%'; OWNER OBJECT_NAME OBJECT_TYPE
    5 --------------- --------------- -------------
    6 SYS DUAL TABLE PUBLIC DUAL SYNONYM

    原来DUAL是属于SYS schema的一个表,然后以PUBLIC SYNONYM的方式供其他数据库USER使用。

    2. 查询Dual的结构和数据

    1 SQL> desc dual Name Null? Type
    2 ----------------------------------------- -------- ----------------------
    3 DUMMY VARCHAR2(1)

    只有一个名字叫DUMMY的字符型COLUMN。

    然后查询一下表里的数据:

    1 SQL> select dummy from dual;
    2 DUMMY
    3 ----------
    4 X

    3. Dual的奇妙之处

    插入一条记录:

    复制代码
     1 SQL> connect sys as sysdba
     2 Connected.
     3 
     4 SQL> insert into dual values ( 'Y');
     5 1 row created.
     6 
     7 SQL> commit;
     8 Commit complete.
     9 
    10 SQL> select count(*) from dual;
    11 COUNT(*)
    12 ----------
    13 2
    复制代码

    再次查询记录时,奇怪的事情发生了:

    1 SQL> select * from dual;
    2 DUMMY
    3 ----------
    4 X

    刚才插入的那条记录并没有显示出来 ! 明明DUAL表中有两条记录, 可就是只显示一条!

    再试一下删除 ,狠一点,全删光!再查询

    复制代码
     1 SQL> delete from dual; /*注意没有限定条件,试图删除全部记录*/
     2 1 row deleted.    -- 只有一条记录被删掉
     3 
     4 SQL> commit;
     5 Commit complete.
     6 
     7 SQL> select * from dual;
     8 DUMMY
     9 ----------
    10 Y
    复制代码

    原来ORACLE对DUAL表的操作做了一些内部处理,尽量保证DUAL表中只返回一条记录.当然这写内部操作是不可见的。

  • 相关阅读:
    匿名方法
    C# 正则表达式
    c# 预处理命令
    反射
    特性(attribute)
    c# 交换两个变量
    构造函数
    泛型
    Event事件
    委托
  • 原文地址:https://www.cnblogs.com/aaaazzzz/p/14298367.html
Copyright © 2011-2022 走看看