MySql类似Oracle的dual虚拟表
2016-04-28 18:10
393 查看
在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条件,决定是否返回结果集
你可千万注意了:
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条件,决定是否返回结果集
相关文章推荐
- Oracle单行函数
- oracle函数
- Oracle学习之路——简单查询
- oracle中CAST函数使用简介 (
- Oracle 11g笔记——数据库关闭
- Oracle 11.2.0.4 + rhel 6.5 x64一个神奇的问题
- oracle for update和for update nowait的区别 - 转
- mysql和oraclesql语法的区别
- oracle 查看锁表 清除锁表
- Oracle 12C优化器的巨大变化,上生产必读(上)
- Oracle 11g笔记——数据库启动
- oracle日期字段只取日期不要时间
- oracle添加字段 与 db2 添加字段
- Oracle中查看所有表和字段以及表注释.字段注释
- Oracle两个数据库互相访问,DBLink使用-转
- oracle 11g审计关闭,及删除日志
- ORACLE的数据类型
- oracle创建用户密码带特殊字符
- linux下oracle11g sys和system忘记密码
- Oracle 创建 DBLink 的方法