关于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目前不支持,用临时表存放结果