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。メニュー項目を選択形式ではなく、ここに記述していないナビゲーションバーでも並べ替えたい。たとえば、最初のカテゴリの名前が「1」で2番目のカテゴリの名前が「3」の場合、メニューの「選択されていない要素」の「2」という名前のカテゴリをそれらの間に挿入したいと思います。
アップデート
ここにスクリプトを挿入しています
<?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と一致しない関数がどのようなものであるか想像できません。