mysql - 如何将单元格中的文本替换为mysql中另一个表中的数据

标签 mysql

我需要你的帮助。

我在 MYSQL 中有一个这样的表

*TABLE1*
id | permission
-- | ----------
a1 | 1,2,3,4,5
v2 | 2,3,4
r1 | 1,3,4,5
b4 |
h7 | 4,5

我还有另一张 table

*TABLE2*
id | permission
-- | ----------
1  | Allow
2  | Not Allow
3  | Disabled
4  | WOW
5  | Grant

我想选择 TABLE1 JOIN TABLE2 但是:新表应该是这样的

*NEW_TABLE*
id | permission
-- | ----------
a1 | Allow,Not Allow,Disabled,WOW,Grant
v2 | Not Allow,Disabled,WOW
r1 | Allow,Disabled,WOW,Grant
b4 |
h7 | WOW,Grant

有没有办法在MYSQL中实现?

最佳答案

那么你可以尝试以下方法:

这是测试设置:

mysql> select * from table1;
+------+------------+
| id   | permission |
+------+------------+
| a1   | 1, 2, 3, 4 |
| v2   | 2, 3, 4    |
+------+------------+
2 rows in set (0.01 sec)



mysql> select * from table2;
+------+------------+
| id   | permission |
+------+------------+
| 1    | Allow      |
| 2    | Not Allow  |
| 3    | Disabled   |
+------+------------+
3 rows in set (0.01 sec)


mysql> select id, GROUP_CONCAT(t2perm) from (SELECT t1.*, t2.id as t2id, t2.permission as t2perm from table2 t2 cross join table1 t1) crs where INSTR(permission, t2id) > 0 group by id;
+------+--------------------------+
| id   | GROUP_CONCAT(t2perm)     |
+------+--------------------------+
| a1   | Allow,Not Allow,Disabled |
| v2   | Not Allow,Disabled       |
+------+--------------------------+
2 rows in set (0.00 sec)

解释一下;首先,交叉连接两个表,这应该会产生笛卡尔积,如下所示:

mysql> SELECT * from table2 cross join table1;
+------+------------+------+------------+
| id   | permission | id   | permission |
+------+------------+------+------------+
| 1    | Allow      | a1   | 1, 2, 3, 4 |
| 1    | Allow      | v2   | 2, 3, 4    |
| 2    | Not Allow  | a1   | 1, 2, 3, 4 |
| 2    | Not Allow  | v2   | 2, 3, 4    |
| 3    | Disabled   | a1   | 1, 2, 3, 4 |
| 3    | Disabled   | v2   | 2, 3, 4    |
+------+------------+------+------------+
6 rows in set (0.00 sec)

从这一点开始,只需选择一个字符串包含在另一个字符串中的行(INSTR(permission, t2id) => 将权限映射到 ids),您将得到以下结果:

mysql> select * from (SELECT t1.*, t2.id as t2id, t2.permission as t2perm from table2 t2 cross join table1 t1) crs where INSTR(permission, t2id) > 0;
+------+------------+------+-----------+
| id   | permission | t2id | t2perm    |
+------+------------+------+-----------+
| a1   | 1, 2, 3, 4 | 1    | Allow     |
| a1   | 1, 2, 3, 4 | 2    | Not Allow |
| v2   | 2, 3, 4    | 2    | Not Allow |
| a1   | 1, 2, 3, 4 | 3    | Disabled  |
| v2   | 2, 3, 4    | 3    | Disabled  |
+------+------------+------+-----------+
5 rows in set (0.00 sec)

现在只需使用 GROUP_CONCAT 聚合结果...

select id, GROUP_CONCAT(t2perm) from (SELECT t1.*, t2.id as t2id, t2.permission as t2perm from table2 t2 cross join table1 t1) crs where INSTR(permission, t2id) > 0 group by id;

关于mysql - 如何将单元格中的文本替换为mysql中另一个表中的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12299506/

相关文章:

php - 重新排序数据库结果

mysql - 使用 phpMyAdmin 备份 MySQL

mysql - 为什么 utf8mb4 列在 MySQL 5.7.22 中拒绝 4 字节字符?

mysql - 更改表以添加使用 UPDATE JOIN 查询设置值的列

php - 如何更新两个表而不收到不明确的错误消息

mysql - 更新具有相同 id 的多行

mysql - 在 WHERE 子句中使用变量会导致查询永远持续

mysql - 如何选择所有帖子的标签?

mysql - 将列添加到 mysql 查询并为其赋值

php - mysqli num rows 的问题