mysql - 在 MySQL 中计算组合 ID,然后将其存储为库存

标签 mysql sql join

好吧,我要为此抓狂了。

我有一个名为 products_bind_variant 的表

itemId int(10)
productId int(10)
variantId int(10)

variantId 引用类型,无论是大小、颜色等。

此表有变体

variantId int(10)
name varchar(150)
grouping varchar(150)

分组值可能是大小、颜色、范围等

我的变体表数据在这里:

|1|Small|Size
|2|Medium|Size
|3|Large|Size
|4|Red|Colour
|5|White|Colour
|6|Blue|Colour
|7|Extra Large|Size
|8|1-3 years|Range
|9|3-10|Range

我的 products_bind_variant 数据在这里:

|1|69|5
|7|69|6
|8|69|8
|9|69|9
|10|69|4
|12|69|1
|18|69|3
|19|69|2
|20|69|7

我想查询出variantId本身的组合,并且只显示同一组的组合的Id。

我尝试使用

SELECT a.productsid,
       a.variantid,
       b.variantid
FROM   products_bind_variant a
       INNER JOIN products_bind_variant b
               ON a.variantid < b.variantid

但是,它会返回 36 个结果,因为它正在将自身与自身进行匹配。我需要它考虑到只查找分组类型之间的组合,即 24 种组合。

基本上就是查询 Id 之类的事情。

所以

69| 1,4,8 适用于小号、红色、1-3 岁

这是我需要生成的组合,但不是名称、variantId

Blue, 1-3 Years, Extra Large
Blue, 3-10 Years, Extra Large
Blue, 1-3 Years, Large
Blue, 3-10 Years, Large
Blue, 1-3 Years, Medium
Blue, 3-10 Years, Medium
Blue, 1-3 Years, Small
Blue, 3-10 Years, Small
Red, 1-3 Years, Extra Large
Red, 3-10 Years, Extra Large
Red, 1-3 Years, Large
Red, 3-10 Years, Large
Red, 1-3 Years, Medium
Red, 3-10 Years, Medium
Red, 1-3 Years, Small
Red, 3-10 Years, Small
White, 1-3 Years, Extra Large
White, 3-10 Years, Extra Large
White, 1-3 Years, Large
White, 3-10 Years, Large
White, 1-3 Years, Medium
White, 3-10 Years, Medium
White, 1-3 Years, Small
White, 3-10 Years, Small

如有任何帮助,我们将不胜感激。

最佳答案

这将产生 24 行:

select
      `colour`, `range`, `size`, cid, sid, rid
from (select variantId cid, name `colour` from  variant where grouping = 'Colour') c
cross join (select variantId sid, name `size` from  variant where grouping = 'Size') s
cross join (select variantId rid, name `range` from  variant where grouping = 'Range') r

+----+--------+-----------+-------------+-----+-----+-----+
|    | colour |   range   |    size     | cid | sid | rid |
+----+--------+-----------+-------------+-----+-----+-----+
|  1 | Red    | 1-3 years | Small       |   4 |   1 |   8 |
|  2 | White  | 1-3 years | Small       |   5 |   1 |   8 |
|  3 | Blue   | 1-3 years | Small       |   6 |   1 |   8 |
|  4 | Red    | 1-3 years | Medium      |   4 |   2 |   8 |
|  5 | White  | 1-3 years | Medium      |   5 |   2 |   8 |
|  6 | Blue   | 1-3 years | Medium      |   6 |   2 |   8 |
|  7 | Red    | 1-3 years | Large       |   4 |   3 |   8 |
|  8 | White  | 1-3 years | Large       |   5 |   3 |   8 |
|  9 | Blue   | 1-3 years | Large       |   6 |   3 |   8 |
| 10 | Red    | 1-3 years | Extra Large |   4 |   7 |   8 |
| 11 | White  | 1-3 years | Extra Large |   5 |   7 |   8 |
| 12 | Blue   | 1-3 years | Extra Large |   6 |   7 |   8 |
| 13 | Red    | 3-10      | Small       |   4 |   1 |   9 |
| 14 | White  | 3-10      | Small       |   5 |   1 |   9 |
| 15 | Blue   | 3-10      | Small       |   6 |   1 |   9 |
| 16 | Red    | 3-10      | Medium      |   4 |   2 |   9 |
| 17 | White  | 3-10      | Medium      |   5 |   2 |   9 |
| 18 | Blue   | 3-10      | Medium      |   6 |   2 |   9 |
| 19 | Red    | 3-10      | Large       |   4 |   3 |   9 |
| 20 | White  | 3-10      | Large       |   5 |   3 |   9 |
| 21 | Blue   | 3-10      | Large       |   6 |   3 |   9 |
| 22 | Red    | 3-10      | Extra Large |   4 |   7 |   9 |
| 23 | White  | 3-10      | Extra Large |   5 |   7 |   9 |
| 24 | Blue   | 3-10      | Extra Large |   6 |   7 |   9 |
+----+--------+-----------+-------------+-----+-----+-----+

唯一产品 ID 的变体表中有 9 行:3 种颜色、2 个范围和 4 个尺寸

SELECT
    b.productid, v.grouping, group_concat(v.name order by v.name separator ',') as variants
FROM products_bind_variant b
inner join variant v on b.variantid = v.variantid
group  by b.productid, v.grouping

+----+-----------+----------+--------------------------------+
|    | productid | grouping |            variants            |
+----+-----------+----------+--------------------------------+
|  1 |        69 | Colour   | Blue,Red,White                 |
|  2 |        69 | Range    | 1-3 years,3-10                 |
|  3 |        69 | Size     | Extra Large,Large,Medium,Small |
+----+-----------+----------+--------------------------------+

使用的数据:

DROP TABLE IF EXISTS products_bind_variant;
CREATE TABLE products_bind_variant(
   itemId    INTEGER  NOT NULL
  ,productId INTEGER  NOT NULL
  ,variantId INTEGER  NOT NULL
);
INSERT INTO products_bind_variant(itemId,productId,variantId) VALUES (1,69,5);
INSERT INTO products_bind_variant(itemId,productId,variantId) VALUES (7,69,6);
INSERT INTO products_bind_variant(itemId,productId,variantId) VALUES (8,69,8);
INSERT INTO products_bind_variant(itemId,productId,variantId) VALUES (9,69,9);
INSERT INTO products_bind_variant(itemId,productId,variantId) VALUES (10,69,4);
INSERT INTO products_bind_variant(itemId,productId,variantId) VALUES (12,69,1);
INSERT INTO products_bind_variant(itemId,productId,variantId) VALUES (18,69,3);
INSERT INTO products_bind_variant(itemId,productId,variantId) VALUES (19,69,2);
INSERT INTO products_bind_variant(itemId,productId,variantId) VALUES (20,69,7);

DROP TABLE if exists variant;
CREATE TABLE variant(
   variantId INTEGER  NOT NULL
  ,name      VARCHAR(11) NOT NULL
  ,grouping  VARCHAR(6) NOT NULL
);
INSERT INTO variant(variantId,name,grouping) VALUES (1,'Small','Size');
INSERT INTO variant(variantId,name,grouping) VALUES (2,'Medium','Size');
INSERT INTO variant(variantId,name,grouping) VALUES (3,'Large','Size');
INSERT INTO variant(variantId,name,grouping) VALUES (4,'Red','Colour');
INSERT INTO variant(variantId,name,grouping) VALUES (5,'White','Colour');
INSERT INTO variant(variantId,name,grouping) VALUES (6,'Blue','Colour');
INSERT INTO variant(variantId,name,grouping) VALUES (7,'Extra Large','Size');
INSERT INTO variant(variantId,name,grouping) VALUES (8,'1-3 years','Range');
INSERT INTO variant(variantId,name,grouping) VALUES (9,'3-10','Range');

关于mysql - 在 MySQL 中计算组合 ID,然后将其存储为库存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53849995/

相关文章:

c++ - MySQL Connector\C++ 中缺少示例目录(从哪里获取它们?)

sql - 通过SSH/Qshell的SQL命令

SQL-Server 将 "USE"与 INNER JOINS 和 "UNION"一起使用

MySQL 使用非唯一 ID 进行内连接

php - 使用mysql数据库详细信息访问亚马逊mysql数据库

mysql - 性能调优-我应该使用循环还是 'OR'来查询一堆东西

sql - 不是独立地连接多个表,而是使用单独的查询?

mysql - 使用 * Like 运算符在 sql 查询中搜索表的所有列

sql - 如何使用查询 array_agg 制作此 sql?

python - 如何在python中将二维数组合并为字符串