@@ -2033,6 +2033,7 @@
if ( !empty($q('meta_key')) ) ( $allowed_keys() = $q('meta_key'); $allowed_keys() = 'meta_value'; + $allowed_keys() = 'meta_value_num'; ) $q('orderby') = urldecode($q('orderby')); $q('orderby') = addslashes_gpc($q('orderby'));
@@ -2056,6 +2057,9 @@
case 'meta_value': $orderby = "$wpdb->postmeta.meta_value"; break; + case 'meta_value_num': + $orderby = "$wpdb->postmeta.meta_value+0"; + break; default: $orderby = "$wpdb->posts.post_" . $orderby; )
Ini adalah pengeditan langsung ke file inti: /wp-includes/query.php Perhatikan tanda plus pada kode di atas menunjukkan baris baru untuk ditambahkan .
Catatan Penulis:
Seorang klien ingin saya menyiapkan bidang khusus yang disebut "Peringkat Panduan" yang memungkinkan mereka menetapkan # 1 - 20 untuk daftar Bar yang mereka posting.
Setelah menjalankan kueri posting, saya menemukan bahwa meta_value diperlakukan sebagai string dan karena itu urutan sortirnya campur aduk:
misalnya. 1, 10, 2, 3css-trick.com C 7, 8, 9
Untuk membuat WordPress / MySQL menggunakan "Urutan Sortir Alami" Anda hanya perlu menerapkan +0 ke nama bidang dan itu akan diperlakukan sebagai angka (mis. Meta_value + 0).
Agar tingkah laku yang ada tidak terganggu saya baru saja menambahkan tipe baru 'meta_value_num'.
Baris kueri saya sekarang terlihat seperti:
$guide_posts = new WP_Query("cat=12&meta_key=guide_rank&orderby=meta_value_num&order=ASC&showposts=10");
Yang mengembalikan: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10
Ini untuk dimasukkan di bagasi WordPress - jadi semoga setelah diterapkan seharusnya tidak perlu mengedit file secara manual.