特殊的数据表dual

转自:https://blog.csdn.net/qq_27289001/article/details/52192025

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

你可千万注意了:

select * from dual;     

mysql会出错——1096:没有使用到表;

而oracle 会返回列:“du”,其值为“X”——行为和只有一行记录的普通表是一样的!

 

select  express [from dual]; 

mysql总是作为返回该表达式值的普通select语句执行,返回一行记录的结果集,from dual 对mysql来说根本就是摆设!

而oracle里该句必须有from dual;否则报错!

 

select  express from dual where 0=2;  

mysq 和 oracle的行为一致:该句就如同你认为的正常表那样——会先计算where的条件,再行计算express;

这里的where条件会决定expres是否会返回!

 

综上:

oracle的dual具有代码美感,风格统一,约定成俗!

不得不说的在sqlserver里,select 有mysql 和 oracle 结合的特点:

select * ;  sqlserver报和mysql类似的错误——你必须指定表。这种完全就算是病句吧,估计谁也不会认的!

select express;   sqlserver 类似于 mysql ,有效语句,返回一行记录的结果集

select express where 0=2;  sqlserver的特色:不需要from子句,考虑where条件,决定是否返回结果集

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值