码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 了解Oracle中的Dual系统表


    首发微信公众号:SQL数据库运维

    原文链接:https://mp.weixin.qq.com/s?__biz=MzI1NTQyNzg3MQ==&mid=2247485212&idx=1&sn=450e9e94fa709b5eeff0de371c62072b&chksm=ea37536cdd40da7a94e165ce4b4c6e70fb1360d51bed4b3566eee438b587fa231315d0a5a5b3&token=1491694448&lang=zh_CN#rd

    这几天一直在研究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数据库当中都不会报错,所以一般做一些特定查询的时候用这个表是最稳妥的。
      1. select sysdate from dual;
      2. --或日期转换获得当前系统时间,‘分钟’ 要用mi;hh24表示24小时制,hh表示12小时制。
      3. select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual;

       

    • 当计算器使用
      select 1024*1024 from dual;
      

    • 查询当前连接用户

      select user from dual;
      

    • 查看序列值

      1. --创建序列aaa 以1开始,每次加1
      2. create sequence aaa increment by 1 start with 1;
      3. --获得序列aaa 的下一个序列值,每次查询加1
      4. select aaa.nextval from dual;
      5. --获得序列aaa 的当前序列值
      6. 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的方式供其他用户使用。

  • 相关阅读:
    Ubuntu22安装JDK17
    Ubuntu安装Redis
    读书笔记:《高频交易员》
    成熟企业级开源监控解决方案Zabbix6.2关键功能实战-上
    4.力扣c++刷题-->删除有序数组中的重复项 II
    Android Studio的debug和release模式及签名配置
    【leetcode】最长斐波那契数列
    [golang 微服务] 1.单体式架构以及微服务架构介绍
    js逆向基础篇-某音乐网站-xx音乐
    (第三百篇BLOG记录)写于博士毕业与入职之初-20230924
  • 原文地址:https://blog.csdn.net/weixin_46329056/article/details/127118991
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号