Backport(バックポート) #1581
完了A community category is sorted not in order of column sort_order of table community_category but in order of ID. (コミュニティカテゴリがテーブルcommunity_categoryのカラムsort_orderではなく、ID順にソートされる)
100%
説明
Overview (現象)¶
2系から3系へアップデートのアップデート時に以下の操作を行うと、コミュニティカテゴリがテーブルcommunity_categoryのカラムsort_orderではなく、ID順にソートされる
前提 ・2.12のときに、コミュニティカテゴリのIDとsort_orderの並びが違う状態 (後から追加し、カテゴリ的には既存のものより上にしたいため) 結果 ・そのデータをupgrade する ・OpenPNE3で参照しているテーブルcommunity_categoryのカラムsort_order ではなく、ID順にソートされてプルダウンメニューに表示される
再現バージョン¶
- OpenPNE2.12 → 3.4.6
Causes (原因)¶
community_category テーブルからレコードを取得する際のSQLで、sort_order カラムを order by に指定していない。
また、管理画面でのソートに対応しておらず、
OpenPNE3 で追加したカテゴリのsort_order カラムの値が null になっています。
Way to fix (修正内容)¶
community_category を取得する際、随所で以下のようなコードとなっている。
Doctrine::getTable('CommunityCategory')->createQuery()->where('lft > 1');
where句の指定はすべて共通であるため、CommunityCategoryTable に getAllChildrenQuery() を追加して共通化し、
このメソッド内で「order by sort_order」を付加するように修正する。
この修正によってコミュニティ検索などのプルダウン選択ではソートが正しく機能するようになりますが、
管理画面ではソート順の反映は行われません。
報告元¶
http://sns.openpne.jp/diary/24997 から転載
2.12から3.4.6へアップデートした環境で、 前提 ・2.12のときに、コミュニティカテゴリのIDとsort_orderの並びが違う状態 (後から追加し、カテゴリ的には既存のものより上にしたいため) 結果 ・そのデータをupgrade する ・OpenPNE3で参照しているテーブルcommunity_categoryのカラムsort_order ではなく、ID順にソートされてプルダウンメニューに表示される
ファイル
Masato Nagasawa さんが約14年前に更新
- 題名 を コミュニティカテゴリがテーブルcommunity_categoryのカラムsort_orderではなく、ID順にソートされる から A community category is sorted not in order of column sort_order of table community_category but in order of ID. (コミュニティカテゴリがテーブルcommunity_categoryのカラムsort_orderではなく、ID順にソートされる) に変更
Masato Nagasawa さんが約14年前に更新
- ステータス を Accepted(着手) から Pending Review(レビュー待ち) に変更
- 進捗率 を 0 から 50 に変更
更新履歴 967546534580768c9755f031b85218c0fc80bbf9 で適用されました。
Shogo Kawahara さんが約14年前に更新
- ステータス を Pending Review(レビュー待ち) から Rejected(差し戻し) に変更
#1528 差し戻しによるステータス変更
Masato Nagasawa さんが約14年前に更新
- ステータス を Rejected(差し戻し) から Pending Review(レビュー待ち) に変更
更新履歴 b01aedcbef8966cdd6eb917fc2a1bdec61c072bc で適用されました。
Masato Nagasawa さんが約14年前に更新
- ステータス を Pending Review(レビュー待ち) から Rejected(差し戻し) に変更
- 対象バージョン を OpenPNE 3.4.8 から OpenPNE 3.4.9 に変更
3.4.9にて対応します。
Masato Nagasawa さんが約14年前に更新
- ステータス を Pending Fixing(修正待ち) から Pending Review(レビュー待ち) に変更
更新履歴 02dd3d16ca6d88215c88353bc2a423e6bd1a81d2 で適用されました。
Mutsumi Imamura さんがほぼ14年前に更新
- ファイル befor_214to34_upgrade.png befor_214to34_upgrade.png を追加
- ファイル after_214to34_upgrade.png after_214to34_upgrade.png を追加
アップグレード動作を確認しましたが、ID順にソートされてしまいました。
再度、ご確認をお願いいたします。
Masato Nagasawa さんがほぼ14年前に更新
- ステータス を Accepted(着手) から Pending Review(レビュー待ち) に変更
管理画面ではソートには対応していません。
チケット #1528 で以下のようにコメントしていましたが、修正内容にこの事を明記していなかったため追記しておきました。
現状カテゴリのソートカラムにはnullが入っているため、 nullのカテゴリについては1より順番が上になります。 コミュニティカテゴリのソート順自体変更する機構が存在していないため、 これについては別チケットで対応する必要があると思います。
Mutsumi Imamura さんがほぼ14年前に更新
管理画面でソートに対応していない件について承知しました。
/mobile_frontend.php/community/searchのデフォルト画面でカテゴリ一覧が表示されますが、その表示順がID順に表示される件については別issuesで対応ということにします。
その他については特に問題ありません。
Rimpei Ogawa さんがほぼ14年前に更新
- ステータス を Pending Review(レビュー待ち) から Pending Testing(テスト待ち) に変更
- 進捗率 を 50 から 70 に変更
Shinichi Urabe さんがほぼ14年前に更新
- ステータス を Pending Testing(テスト待ち) から Fixed(完了) に変更
- 進捗率 を 70 から 100 に変更
Imamura Mutsumi は書きました:
管理画面でソートに対応していない件について承知しました。
/mobile_frontend.php/community/searchのデフォルト画面でカテゴリ一覧が表示されますが、その表示順がID順に表示される件については別issuesで対応ということにします。その他については特に問題ありません。
上記は #1796 を作りました。このチケットはクローズします