zoukankan      html  css  js  c++  java
  • Mysql:语法:虚拟表DUAL

    在mysql里也存在和oracle里类似的dual虚拟表:官方声明纯粹是为了满足select ... from...这一习惯问题,mysql会忽略对该表的引用。

    你可千万注意了:

    1. select * from dual;     mysql会出错——1096:没有使用到表;而oracle 会返回列:“du”,其值为“X”——行为和只有一行记录的普通表是一样的!
    2. select  express [from dual];  mysql总是作为返回该表达式值的普通select语句执行,返回一行记录的结果集,from dual 对mysql来说根本就是摆设!而oracle里该句必须有from dual;否则报错!
    3. select  express from dual where 0=2;   mysq 和 oracle的行为一致:该句就如同你认为的正常表那样——会先计算where的条件,再行计算express;这里的where条件会决定expres是否会返回!

    综上:

    • oracle的dual具有代码美感,风格统一,约定成俗!
    • 不得不说的在sqlserver里,select 有mysql 和 oracle 结合的特点:
    1. select *   sqlserver报和mysql类似的错误——你必须指定表。这种完全就算是病句吧,估计谁也不会认的!
    2. select express   sqlserver 类似于 mysql ,有效语句,返回一行记录的结果集
    3. select express where 0=2  sqlserver的特色:不需要from子句,考虑where条件,决定是否返回结果集
  • 相关阅读:
    Win32API界面库
    C++模板元编程
    C++模板元编程
    00,跨域的问题
    05,总结——关于用户登录以及注册
    04,Django Form源码阅读
    03,Django的认证系统——auth模块
    用户登录
    用户注册与忘记密码邮箱激活
    DjangoForm表单的基础
  • 原文地址:https://www.cnblogs.com/jinzhenshui/p/1503505.html
Copyright © 2011-2022 走看看