日期:2014-05-16  浏览次数:21165 次

关于with用法的问题
WITH (`employeecompanycity`(`employee_name`,`city`))
AS
(
SELECT `employee_name` , `city`
FROM `works`,`company`
WHERE `works`.`company_name` = `company`.`company_name`)
我在mysql中如上用了with保存中间表的结果却一直抱1046的错,请问是什么问题?AS中的部分没有错误

------解决方案--------------------
MySQL 中不支持这个WITH的语法.

你可以参考一下手册中MYSQL所支持的SQL语法
MySQL官方文档 http://dev.mysql.com/doc/refman/5.1/zh/index.html
------解决方案--------------------
with这个应该是db2 的语法吧 。不是标准的sql,所以mysql中不能使用。


------解决方案--------------------
那MYSQL是怎么保存中间结果的呢?

用个临时表吧。

create TEMPORARY table employeecompanycity SELECT `employee_name` , `city`
FROM `works`,`company`
WHERE `works`.`company_name` = `company`.`company_name`
------解决方案--------------------
SQL2005、ORACLE、ASA11支持WITH,MYSQL目前不支持,用临时表存放结果