• 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表中只返回一条记录.当然这写内部操作是不可见的。

  • 相关阅读:
    mysql之alter 字段的修改、添加、删除
    mysql之Percona-XtraDB-Cluster prohibits without an explicit primary key with pxc_strict_mode = ENFORCING or MASTER报错
    mysql之常用操作,创建库、表,删除库、表
    Spring Boot的消息之旅(一)
    Spring Boot的日志之旅(一)
    Spring Boot的缓存之旅(二)
    Spring Boot的缓存之旅(一)
    使用Druid数据库连接池
    Spring Boot的数据库之旅(二)
    Spring Boot的安全之旅(一)
  • 原文地址:https://www.cnblogs.com/rxhuiu/p/9117209.html
Copyright © 2020-2023  润新知