gpt4 book ai didi

MySQL高效数据转联表查询

转载 作者:可可西里 更新时间:2023-11-01 08:02:33 26 4
gpt4 key购买 nike

问题:

我想将表 companies_1 中的类别链接移动到 company_categories 表中。 company_categories 表中的company_id 需要等于companies_2 表的idcompanies_1companies_2 表的记录由“name”列链接。

  • 下面的当前代码花了我一个晚上的时间,仍未完成!我想学习提高效率并加快这一进程。我觉得有很多需要优化的地方,因为有很多公司记录。
  • 另一个问题是我发现无法在循环时检查查询的位置(导致无法检查进度)。因为进展花了很长时间,所以我终止了查询,我正在寻找更好的方法来解决这个问题。

信息:

有一张表,公司如下:

----------------------------------------
| companies_1 |
----------------------------------------
| id | category_id | name |
----------------------------------------
| 1 | 1 | example-1 |
| 2 | 2 | example-1 |
| 3 | 1 | example-2 |
| 4 | 2 | example-2 |
| 5 | 3 | example-2 |
| 6 | 1 | example-3 |
----------------------------------------

具有不同公司名称的表:

-------------------------
| companies_2 |
-------------------------
| id | name |
-------------------------
| 1 | example-1 |
| 2 | example-2 |
| 3 | example-3 |
-------------------------

类别表,例如:

-------------------------
| categories |
-------------------------
| id | name |
-------------------------

还有一个联结表,例如:

---------------------------------
| company_categories |
---------------------------------
| company_id | category_id |
---------------------------------

当前代码:

此代码有效,但效率不高。

DELIMITER $$
DROP PROCEDURE IF EXISTS fill_junc_table$$
CREATE PROCEDURE fill_junc_table()
BEGIN
DECLARE r INT;
DECLARE i INT;
DECLARE i2 INT;
DECLARE loop_length INT;
DECLARE company_old_len INT;
DECLARE _href VARCHAR(255);
DECLARE cat_id INT;
DECLARE comp_id INT;

SET r = 0;
SET i = 0;
SET company_old_len = 0;
SELECT COUNT(*) INTO loop_length FROM companies;

WHILE i < loop_length DO
SELECT href INTO _href FROM company_old LIMIT i,1;
SELECT id INTO comp_id FROM companies WHERE site_href=_href;
SELECT COUNT(*) INTO company_old_len FROM company_old WHERE href=_href;
SET i2 = 0;
WHILE i2 < company_old_len DO
SELECT category_id INTO cat_id FROM company_old WHERE href=_href LIMIT i2,1;
INSERT INTO company_categories (company_id, category_id) VALUES (comp_id, cat_id);
SET r = r + 1;
SET i2 = i2 + 1;
END WHILE;
SET i = i + 1;
END WHILE;

SELECT r;
END$$
DELIMITER ;

CALL fill_junc_table();

编辑(新想法):

我将测试另一种解决此问题的方法,即完全复制具有以下列的 companies_1 表(复制时 company_id 为空):

---------------------------------------------
| company_id | category_id | name |
---------------------------------------------

然后,我将遍历 companies_2 表以填充与名称列相关的正确 company_id。

希望您能就此发表您的看法。当我完成测试后,我会将结果留在这里供其他人使用。

最佳答案

澄清一下,我在 company_categories 中没有看到任何 PIVOT 转换。我看到的是你想要一个 JUNCTION TABLE因为 companiescategories 表似乎具有多对多 关系。

在您的例子中,您有 company,它有 多个 类别。您还为多个公司分配了类别

现在根据您的要求:

I want to move the links of the categories from the table companies_1 into the company_categories table. The company_id in the company_categories table need to be equal to the id of the companies_2 table. The records of the companies_1 and the companies_2 table are linked by the "name"-column.

我带着这个查询来到这里:

INSERT INTO company_categories (company_id, category_id)
SELECT C2.id
, C1.category_id
FROM companies_1 C1
INNER JOIN companies_2 C2 ON C2.name = C1.name

让我知道这是否可行。您创建的嵌套循环确实需要一段时间。

正如@DanielE 所指出的,此查询将在 company_categories 为空的假设下工作。否则我们将需要使用 UPDATE

关于MySQL高效数据转联表查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49645209/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com