繁体   English   中英

SQL 将两个表以特定方式绑定到一个 SQL 语句

[英]SQL bind two tables into one SQL statement in a specific way

我有两个带有列的 SQL 表:

菜单:

  • 编号 [人工智能]
  • 姓名
  • 描述

子类别:

  • 编号 [AI]
  • 姓名
  • pid(子类别父 ID)
  • 中间(菜单编号)

在我的网站的新版本中,不再有菜单,“子类别”现在变成了“类别”:

  • ID
  • 姓名
  • 描述
  • parent_id

旧数据库仍在使用中,所以我正在制作迁移脚本,这是带有类别的部分:

$new_db->query("TRUNCATE TABLE `categories`");
$ids = [];
$menu_list = $old_db->fetch("SELECT * FROM `menu` ORDER BY `id`");
foreach($menu_list as $menu)
{
    $id = $new_db->insert("categories", [
        "name" => $menu["name"],
        "description" => $menu["description"],
        "parent_id" => "0"
    ]);
    $ids[$menu["id"]] = $id;
    
}
$subcategories = $old_db->fetch("SELECT * FROM `subcategories` ORDER BY `id`");
foreach($subcategories as $subcategory)
{
    $pid = 0;
    $desc = "";
    if($subcategory["mid"] > 0)
    {
        $menu = $old_db->fetch_first("SELECT `id`, `description` FROM `menu` WHERE `id` = '".$subcategory["mid"]."' LIMIT 1");
        $pid = $ids[$menu["id"]];
        $desc = $menu["description"];
    }
    else
    {
        $pid = $subcategory["pid"];
    }
    $new_db->insert("categories", [
        "name" => $subcategory["name"],
        "description" => $desc,
        "parent_id" => $pid
    ]);
}

它有效,但我很确定它可以用更少的成本做得更好。 我可以创建一个 SQL 语句,将菜单和子类别绑定到一个结果列表中,然后将它们全部插入吗?

我想你只是想要一个JOIN

SELECT * 
FROM `categories` c 
JOIN `subcategiries` s
ON s.pid = c.id

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM