0

由于某些原因,执行以下查询时出现以下错误:

您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以在第 35 行的“ENGINE=FEDERATED”附近使用正确的语法

CREATE TABLE users AS (
  SELECT
    ID, user_email, user_registered,
    first_name.meta_value as first_name,
    last_name.meta_value as last_name,
    telephone.meta_value as telephone,
    country.meta_value as country,
    company.meta_value as company,
    address.meta_value as address,
    city.meta_value as city,
    professional_title.meta_value as professional_title,
    state.meta_value as state,
    areas_of_interest.meta_value as areas_of_interest
    FROM wp_users
    LEFT JOIN wp_usermeta AS first_name ON first_name.user_id=ID
        AND first_name.meta_key='first_name'
    LEFT JOIN wp_usermeta AS last_name ON last_name.user_id=ID
        AND last_name.meta_key='last_name'
    LEFT JOIN wp_usermeta AS telephone ON telephone.user_id=ID
        AND telephone.meta_key='telephone'
    LEFT JOIN wp_usermeta AS country ON country.user_id=ID
        AND country.meta_key='country'
    LEFT JOIN wp_usermeta AS company ON company.user_id=ID
        AND company.meta_key='company'
    LEFT JOIN wp_usermeta AS address ON address.user_id=ID
        AND address.meta_key='address'
    LEFT JOIN wp_usermeta AS city ON city.user_id=ID
        AND city.meta_key='city'
    LEFT JOIN wp_usermeta AS professional_title ON professional_title.user_id=ID
        AND professional_title.meta_key='professional_title'
    LEFT JOIN wp_usermeta AS state ON state.user_id=ID
        AND state.meta_key='state'
    LEFT JOIN wp_usermeta AS areas_of_interest ON areas_of_interest.user_id=ID
        AND areas_of_interest.meta_key='areas_of_interest'
) ENGINE=FEDERATED DEFAULT CHARSET=latin1 CONNECTION "*****";

注意: FEDERATED Engine 已打开并正在处理其他未连接的表。

4

1 回答 1

0

简短的回答:
FEDERATED 表的 CREATE 语句需要额外的一条数据,称为 CONNECTION。语句中没有这些数据是语法错误的根源。

长答案:

对于这个特定的实例,VIEW 将是比 FEDERATED 表更好的工具。

FEDERATED 存储引擎可以类似于 Linux 中的符号链接或 Windows 中的快捷方式。它主要用于访问服务器上的表,该服务器实际上并不在本地存储表,而是在不同的 mysql 服务器上。因此,当您创建 FEDERATED 表时,您还必须在 CREATE 语句中包含 FEDERATED 存储引擎应该使用的 CONNECTION。您可以选择在存储数据的同一主机上创建一个 FEDERATED 表,但这会导致由于访问本地数据所采取的不必要步骤而导致的额外开销。请参阅此链接了解更多详情。

另一方面,一个 VIEW 就像一个存储查询,每当您查询 VIEW 表时都会执行。 此页面可以为您提供更多信息。

于 2014-11-14T14:29:49.853 回答