我寫了動態菜單Php和MySql。這裏是我的MySQL表結構=>菜單項動態排序php 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">
怎麼可以看到的傢伙,我試圖與選擇元素的幫助菜單項(與排序sort_id列),但我無法下定決心如何在MySql表中使用sort_id數字來操作,如何增加或減少來實現目標。
請幫忙,如果有人知道該怎麼做或有想法?
PS。我想排序菜單項不選擇形式,但也在導航欄,我沒有寫在這裏。 例如,如果第一類被命名爲「一個」和第二個「三」,我想他們之間插入類別中的菜單命名爲「兩個」 NOT IN選擇元素
UPDATE
這裏插入腳本
<?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手動號碼,這是非常糟糕的,但我沒有別的想法。從相同的元素(我是指select元素)中多次插入類別後,我感到困惑。原因是,增加值1,但我無法想象什麼函數會很好不匹配sort_id -s在列
你的id是自動增加的。當插入表中的東西時,你應該忽略填充'id',只做'sort_id'和'title'。我的問題變成了如何確定'sort_id'? – 2012-08-08 13:13:33
在您的選擇框中寫入ASC/DESC的類別? – diEcho 2012-08-08 13:13:54
@diEcho ASC是在查詢中寫的,就像上面顯示的那樣 – tnanoba 2012-08-08 13:15:04