首页 / PHP / 如何通过反复查询数据库使PHP发挥作用
如何通过反复查询数据库使PHP发挥作用
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了如何通过反复查询数据库使PHP发挥作用,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3696字,纯文字阅读大概需要6分钟。
内容图文
![如何通过反复查询数据库使PHP发挥作用](/upload/InfoBanner/zyjiaocheng/883/31ad017d954040588d529ca257df21fc.jpg)
我的代码正在运行,但我对此不满意,它看起来很脏.
我的问题是,如何使我的代码不重复出现.
这是我的代码,
<?php
// PARENT MENU
$q2 = "SELECT t.*, t2.id as m_id FROM userpage t left join menu t2 on (t2.parent=t.parent and t2.sort=t.sort) WHERE t.parent = (SELECT MIN(parent) from userpage) ORDER BY t.sort ASC";
$r2 = $db->query($q2);
$a2 = $db->fetch_all_array($q2);
foreach($a2 as $k => $v)
{
$indent = "➥";
$tab = " ";
$menu_id = $v['m_id'];
echo $v['pagename'] . "(" . $v['page'] . ")";
// 1ST SUB MENU
if ($menu_id != '')
{
$q3 = "SELECT t.*, t2.id as m_id FROM userpage t left join menu t2 on (t2.parent=t.parent and t2.sort=t.sort) WHERE t.parent = " . $menu_id . " ORDER BY t.sort ASC";
$r3 = $db->query($q3);
$a3 = $db->fetch_all_array($q3);
foreach($a3 as $k3 => $v3)
{
$menu_id2 = $v3['m_id'];
echo $v3['pagename'] . "(" . $v3['page'] . ")";
// 2ND SUB MENU
if ($menu_id2 != '')
{
$q4 = "SELECT t.*, t2.id as m_id FROM userpage t left join menu t2 on (t2.parent=t.parent and t2.sort=t.sort) WHERE t.parent = " . $menu_id2 . " ORDER BY t.sort ASC";
$r4 = $db->query($q4);
$a4 = $db->fetch_all_array($q4);
foreach($a4 as $k4 => $v4)
{
$menu_id3 = $v4['m_id'];
echo $v4['pagename'] . "(" . $v4['page'] . ")";
// 3RD SUB MENU
if ($menu_id3 != '')
{
$q5 = "SELECT t.*, t2.id as m_id FROM userpage t left join menu t2 on (t2.parent=t.parent and t2.sort=t.sort) WHERE t.parent = " . $menu_id3 . " ORDER BY t.sort ASC";
$r5 = $db->query($q5);
$a5 = $db->fetch_all_array($q5);
foreach($a5 as $k5 => $v5)
{
$menu_id4 = $v5['m_id'];
echo $v5['pagename'] . "(" . $v5['page'] . ")";
// 4TH SUB MENU
if ($menu_id4 != '')
{
$q6 = "SELECT t.*, t2.id as m_id FROM userpage t left join menu t2 on (t2.parent=t.parent and t2.sort=t.sort) WHERE t.parent = " . $menu_id4 . " ORDER BY t.sort ASC";
$r6 = $db->query($q6);
$a6 = $db->fetch_all_array($q6);
foreach($a6 as $k6 => $v6)
{
$menu_id5 = $v6['m_id'];
echo $v6['pagename'] . "(" . $v6['page'] . ")";
// 5TH SUB MENU
if ($menu_id5 != '')
{
$q7 = "SELECT t.*, t2.id as m_id FROM userpage t left join menu t2 on (t2.parent=t.parent and t2.sort=t.sort) WHERE t.parent = " . $menu_id5 . " ORDER BY t.sort ASC";
$r7 = $db->query($q7);
$a7 = $db->fetch_all_array($q7);
foreach($a7 as $k7 => $v7)
{
$menu_id6 = $v7['m_id'];
echo $v['pagename'] . "(" . $v['page'] . ")";
} //5th submenu
} //closing if for 5th submenu
} //4th submenu
} //closing if for 4th submenu
} //3rd submenu
} //closing if for 3rd submenu
} //2nd submenu
} //closing if for 2nd submenu
} //1st submenu
} //closing if for 1st submenu
} //parent menu
?>
谢谢.
任何答案都受到高度赞赏.
解决方法:
您可以更改代码以使用递归.执行此操作的最简单方法仍将多次调用数据库,但您无需在代码中全部使用它们.
调用下面的函数将写出子菜单及其所有子代/子代等.
它使用recursion起作用,在这种情况下,意味着函数调用自身以完成其任务.
function subMenu($menu_id) {
$q = "SELECT t.*, t2.id as m_id FROM userpage t left join menu t2 on (t2.parent=t.parent and t2.sort=t.sort) WHERE t.parent = " . $menu_id . " ORDER BY t.sort ASC";
$r = $db->query($q);
$a = $db->fetch_all_array($q);
foreach($a2 as $k => $v)
{
$menu_id2 = $v['m_id'];
echo $v['pagename'] . "(" . $v['page'] . ")";
if ($menu_id2 != '') {
// write out the submenu of this submenu
subMenu($menu_id2);
}
}
}
带有缩进计数器.将0传递给indent_count
function subMenu($menu_id, $indent_count) {
$q = "SELECT t.*, t2.id as m_id FROM userpage t left join menu t2 on (t2.parent=t.parent and t2.sort=t.sort) WHERE t.parent = " . $menu_id . " ORDER BY t.sort ASC";
$r = $db->query($q);
$a = $db->fetch_all_array($q);
foreach($a2 as $k => $v)
{
$menu_id2 = $v['m_id'];
// You need to add in an indent based on $indent_count
echo $v['pagename'] . "(" . $v['page'] . ")";
if ($menu_id2 != '') {
// write out the submenu of this submenu
subMenu($menu_id2, $indent_count + 1);
}
}
}
内容总结
以上是互联网集市为您收集整理的如何通过反复查询数据库使PHP发挥作用全部内容,希望文章能够帮你解决如何通过反复查询数据库使PHP发挥作用所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。