我用Php和MySql编写了动态菜单。这是我的 MySql 表结构 =>
CREATE TABLE MENU(
id INT(3) NOT NULL AUTO_INCREMENT PRIMARY KEY,
sort_id BIGINT NOT NULL,
title VARCHAR(50) NOT NULL,
etc ...);
这是html表单=>
<input type="text" name="title">
<select name="pos">
<?php
if ($r = $connection->query("SELECT id,sort_id,title from menu order by sort_id ASC")){
$row = $r->fetch_assoc();
/* here with help of php I'm retrieving data from marked table. I need this because want to sort categories with help of this select element , forward or backwards */
echo "<option value='" . $row['id'] . "'>" . $row['title'] . " After</option>";
}
?>
</select>
<input type="submit" name="ok">
你怎么能看到伙计们,我正在尝试借助 select 元素(带有 sort_id 列)对菜单项进行排序,但我无法决定如何使用 MySql 表中的sort_id数字进行操作,如何增加或减少来实现目标。
请帮忙,如果有人知道该怎么做或有想法吗?
PS。我想对菜单项进行排序,而不是选择形式,而是在导航栏中,我没有在这里写。例如,如果第一个类别名为“one”,第二个类别为“three”,我想在菜单 NOT IN SELECT ELEMENT 中插入名为“two”的类别
更新
这是插入脚本
<?php
$main_sort_res = $connection->query("SELECT sort_id FROM menu WHERE id=" . $_POST['pos'] . "");
$sort_num = $main_sort_res->fetch_assoc();
if ($k = $con->query("SELECT id FROM menu WHERE id=" . $_POST['pos'] . " AND sort_id=(SELECT MAX(m_sort_id) FROM main_menu)")){ // here defined if selected element is last or not
if ($k->num_rows==0){ // not last element
$connection->query("INSERT INTO menu(sort_id,title) VALUES(" . ($sort_num['sort_id']+1) . ",NULL,'" . $_POST['title'] . "')")
} else { // last element in select form
$connection->query("INSERT INTO menu(sort_id,title) VALUES(" . ($sort_num['sort_id']+10000) . ",NULL,'" . $_POST['title'] . "')")
}
}
?>
你怎么看我在 sort_id 中手动插入数字,这很糟糕,但我没有其他想法。从同一元素(我的意思是从选择元素)多次插入类别时,我感到困惑。原因是增加值 1 ,但我无法想象什么函数不匹配列中的 sort_id-s