mysql - 数据库查询 - 按两个值排序(嵌套顺序)

标签 mysql database wordpress database-design database-schema



我想按两个数据库值对结果进行排序: rating_full 后跟 rating_count

目前,我按最高的 rating_full 排序。效果很好。

$sql .= " LEFT JOIN {$wpdb->postmeta} rating ON ({$wpdb->posts}.ID = rating.post_id AND rating.meta_key IN ('rating_full'))";

$sql = "cast(rating.meta_value as decimal(10,2)) {$order}";

……

第一行代码是 SELECT 语句的一部分,检索 rating_full 部分

第二行代码是ORDER BY部分,目前仅使用 rating_count

据我所知,第二行代码中引用的 rating.meta_value rating_full

我正在尝试将其按 rating_full rating_count 排序 我不知道如何修改第一行才能实现这一目标。


谢谢

完整代码:

<?php

// Sorting
add_filter('posts_join', 'directorySortingJoin',10,2);
function directorySortingJoin($join, $query) {
global $wpdb, $aThemeOptions;
if ($query->is_main_query() && !$query->is_admin &&   ((isset($_GET['dir-search'])) || (isset($query->query_vars["a-dir-item-category"])) || (isset($query->query_vars["a-dir-item-location"])))) {
    $sql = "";
    // default ordering
    $orderby = (isset($aThemeOptions->directory->defaultOrderby)) ? $aThemeOptions->directory->defaultOrderby : 'post_date';
    // get from get parameters
    if (!empty($_GET['orderby'])) {
        $orderby = $_GET['orderby'];
    }
    if ($orderby == 'rating') {
        $sql .= " LEFT JOIN {$wpdb->postmeta} rating ON   ({$wpdb->posts}.ID = rating.post_id AND rating.meta_key IN ('rating_full'))";

        //$sql .= " LEFT JOIN {$wpdb->postmeta} rating ON (wp_posts.ID = rating.post_id AND rating.meta_key IN ('rating_full')) LEFT JOIN {$wpdb->postmeta} count ON ({$wpdb->posts} = count.post_id AND count.meta_key IN ('rating_count'))";


    }
    if ($orderby == 'packages') {
        directorySaveUserPackagesToDb();
        $sql .= " LEFT JOIN {$wpdb->usermeta} packages ON ({$wpdb->posts}.post_author = packages.user_id AND packages.meta_key IN ('dir_package'))";
    }
    if (isset($aThemeOptions->directory->showFeaturedItemsFirst)) {
        $sql .= " LEFT JOIN {$wpdb->postmeta} featured ON ({$wpdb->posts}.ID = featured.post_id AND featured.meta_key IN ('dir_featured'))";
    }
    $join .= $sql;
    //echo $join;
}
return $join;

  }
   add_filter('posts_orderby', 'directorySortingOrderby',10,2);
  function directorySortingOrderby($orderby, $query) {
    global $wpdb, $aThemeOptions;
 if ($query->is_main_query() && !$query->is_admin && ((isset($_GET['dir-search'])) || (isset($query->query_vars["a-dir-item-category"])) || (isset($query->query_vars["a-dir-item-location"])))) {
    $sql = "";
    // default ordering
    $orderby = (isset($aThemeOptions->directory->defaultOrderby)) ? $aThemeOptions->directory->defaultOrderby : 'post_date';
    $order = (isset($aThemeOptions->directory->defaultOrder)) ?   $aThemeOptions->directory->defaultOrder : 'DESC';
    // get from get parameters
    if (!empty($_GET['orderby'])) {
        $orderby = $_GET['orderby'];
    }
    if (!empty($_GET['order'])) {
        $order = $_GET['order'];
    }
    if ($orderby == 'rating') {
        if (isset($aThemeOptions->directory->showFeaturedItemsFirst)) {
            $sql = "featured.meta_value DESC, convert(rating.meta_value, decimal) {$order}";
        } else {
            //$sql = "convert(rating.meta_value, decimal)    {$order}";

            $sql = "cast(rating.meta_value as   decimal(10,2)) {$order}";
            //$sql = "cast(rating.meta_value as decimal(10,2)) {$order}, count.meta_value {$order}";

        }
    } else if ($orderby == 'packages') {
        if (isset($aThemeOptions->directory->showFeaturedItemsFirst)) {
            $sql = "featured.meta_value DESC, packages.meta_value {$order}";
        } else {
            $sql = "packages.meta_value {$order}";
        }
    } else {
        if (isset($aThemeOptions->directory->showFeaturedItemsFirst)) {
            $sql = "featured.meta_value DESC, {$wpdb->posts}.{$orderby} {$order}";
        }
    }
    $orderby = $sql;
    //echo $orderby;
}
return $orderby;
}
// Save directory packages for sorting
function directorySaveUserPackagesToDb() {
$users = get_users();
// capabilities list
$roles = array(
    'administrator' => 10,
    'directory_5' => 9,
    'directory_4' => 8,
    'directory_3' => 7,
    'directory_2' => 6,
    'directory_1' => 5,
    'editor' => 4,
    'author' => 3,
    'contributor' => 2,
    'subscriber' => 1
);
foreach ($users as $user) {
    if (isset($user->roles[0])) {
        if (array_key_exists($user->roles[0], $roles)) {
            update_user_meta($user->ID, 'dir_package',    $roles[$user->roles[0]]);
        } else {
            update_user_meta($user->ID, 'dir_package',   0);
        }
    }
}
}

最佳答案

MySQL documentation for ORDER BY 在这里应该很有帮助,特别是关于对多列进行排序的最后一段。

您的ORDER BY应该类似于

ORDER BY rating_full DESC, rating_count DESC

关于mysql - 数据库查询 - 按两个值排序(嵌套顺序),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29502177/

相关文章:

sql - 关系数据库设计 (MySQL)

wordpress - WooCommerce 订单状态完成时更新产品库存数量和库存状态

html - 定位嵌套在两个 div 类中的元素

css - 将重力形式元素移动到另一个容器中

sql - 是否可以创建一个了解当前模式/库名称的 View ?

java - hibernate 错误 :cannot parse configuration file

mysql - 查询多个表

php - 如何将 md5 ("test"的 php 结果存储在 MySQL MyISAM 表的 BINARY 字段中

mysql - 无法使用 mysql 命令行使用 Unicode 字符

php - 使用 PHP 或 MySql 从其他人的结果创建一个新的 MySql 列