6

我有一个 MySQL 数据库,其中每个用户都有一个帐户,每个帐户可以有多个权限。

我的最终目标是最终得到帐户的用户名和以逗号分隔的权限 ID 列表。有两种方法可以做到这一点:

SELECT a.username, GROUP_CONCAT(rp.permission_id) as permission_ids
FROM account AS a
JOIN role_permission AS rp
ON rp.role_id = a.role_id
WHERE a.id = 1902

... 或者 ...

SELECT username
FROM account
WHERE id = 1902;

SELECT permission_id
FROM account_permission
WHERE account_id = 1902

通过单个查询,我得到了我想要的结果。通过两个查询,我必须使用第二个结果集在应用程序 (PHP) 中创建逗号分隔列表。

是否有任何性能原因不选择第一个选项?我以前从未使用过 GROUP_CONCAT,所以我不知道它的含义,性能方面。

4

1 回答 1

7

性能应该还可以 - 比两个查询要好。您需要注意长度是有限的:

结果被截断为由group_concat_max_len系统变量给出的最大长度,其默认值为 1024。该值可以设置得更高,尽管返回值的有效最大长度受 max_allowed_pa​​cket 值的限制。在运行时更改 group_concat_max_len 值的语法如下,其中 val 是无符号整数:

SET [GLOBAL | SESSION] group_concat_max_len = val;
于 2009-10-13T08:14:05.497 回答