[英]SQL bind two tables into one SQL statement in a specific way
我有两个带有列的 SQL 表:
菜单:
子类别:
在我的网站的新版本中,不再有菜单,“子类别”现在变成了“类别”:
旧数据库仍在使用中,所以我正在制作迁移脚本,这是带有类别的部分:
$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.