1

我看到了这个复杂的选择语句,它有几个组成部分:别名和子查询

SELECT
    u.ID, u.username, u.active, u.email, u.admin, u.banned, u.name,
    (SELECT
        GROUP_CONCAT( g.name SEPARATOR'-groupsep-' ) FROM groups g,
        group_memberships gm
        WHERE g.ID = gm.group AND gm.user = u.ID
    ) AS groupmemberships
    FROM users u WHERE u.ID={$uid}

对我来说没有意义的部分是部分AS groupmemberships

它是什么别名?后面的元素u.name

我不熟悉子查询语法。

任何有用的解释和官方文档的链接都会有所帮助。

4

3 回答 3

1

此查询在查询的FROM子句中使用子查询。子查询返回一组行,这些行又被其余查询用作表。在 MySQL 中,必须为此“虚拟表”提供别名。

所以具体来说,名称groupmemberships是指结果集来自

   SELECT
       GROUP_CONCAT( g.name SEPARATOR'-groupsep-' )
   FROM
       groups g, group_memberships gm
   WHERE
       g.ID = gm.group
       AND gm.user = u.ID

更详细的解释可以在MySQL 文档中找到关于 FROM 子句中的子查询

于 2013-08-07T22:21:11.110 回答
1

来自Mysql 手册

子查询在 SELECT 语句的 FROM 子句中是合法的。实际语法是:

SELECT ... FROM (子查询) [AS] 名称 ...

[AS] name 子句是强制性的,因为 FROM 子句中的每个表都必须有一个名称。

所以基本上我可以给我的结果表一个名字,并在外部查询中使用它作为一个表本身。

希望有帮助:)

于 2013-08-07T22:23:24.483 回答
0

它是子查询结果的列名。没什么不同的说

Select V1,V2,(V1 + V2) As Total From SomeTableOfVs
于 2013-08-07T22:21:13.893 回答