打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
MySql类似Oracle的dual虚拟表
userphoto

2015.09.08

关注

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

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
Mysql、sqlserver、oracle指定返回记录数
orcale 11,dual作用
数据库理论
最新Oracle 和 mysql 的对比参照----开发篇
Oracle数据库移植到MySQL实战
sqlserver复制表数据到另一个表
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服