首頁 > 資料庫 > mysql教程 > MySQL类似Oracle的dual虚拟表

MySQL类似Oracle的dual虚拟表

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-06-07 16:56:46
原創
1437 人瀏覽過

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

在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条件,决定是否返回结果集

linux

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
redis 可以實作類似mysql的高階排序嗎?
來自於 1970-01-01 08:00:00
0
0
0
如何在MySQL中傳回透視表的輸出?
來自於 1970-01-01 08:00:00
0
0
0
mysql配置沒問題,但不顯示中文;
來自於 1970-01-01 08:00:00
0
0
0
如何在MySQL中產生資料透視表的輸出?
來自於 1970-01-01 08:00:00
0
0
0
mongodb - mongo如何實作mysql類似的巢狀查詢。
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板