Mysql CakePHP排序顺序不影响所有记录

Mysql CakePHP排序顺序不影响所有记录,mysql,sorting,cakephp,cakephp-2.x,cakephp-2.7,Mysql,Sorting,Cakephp,Cakephp 2.x,Cakephp 2.7,在我的CakePHP 2.7.7应用程序中,我遇到了一个问题,即使用PaginatorComponent无法正确排序结果。有关图像,请参见此链接: 数据应该按姓氏降序排序,但您可以看到有几个用户似乎不受此数据的影响。不管我按什么顺序做,升序还是降序,这几条记录都不会被排序。供参考: UsersController中的索引(): public function index() { $this->User->contain('Status'); $this->pa

在我的CakePHP 2.7.7应用程序中,我遇到了一个问题,即使用PaginatorComponent无法正确排序结果。有关图像,请参见此链接:

数据应该按姓氏降序排序,但您可以看到有几个用户似乎不受此数据的影响。不管我按什么顺序做,升序还是降序,这几条记录都不会被排序。供参考:

UsersController中的索引():

public function index() {
    $this->User->contain('Status');
    $this->paginate = array(
        'limit' => 15,
        'order' => array('User.last_name' => 'DESC'),
        'conditions' => array('User.department_id =' => $this->Session->read('Auth.User.department_id')),
        'contain' => 'Status'
    );
    $this->set('users', $this->Paginator->paginate());
}
你知道这是什么原因吗?我在这里不知所措。提前谢谢

SELECT `User`.`id`, `User`.`first_name`, `User`.`last_name`, `User`.`middle`, `User`.`address`, `User`.`address_2`, `User`.`city`, `User`.`state_id`, `User`.`zip`, `User`.`home`, `User`.`cell`, `User`.`work`, `User`.`email`, `User`.`status_id`, `User`.`status_reason`, `User`.`rank`, `User`.`birthday`, `User`.`gender`, `User`.`school`, `User`.`employer`, `User`.`position`, `User`.`created`, `User`.`modified`, `User`.`updated_by`, `User`.`radio`, `User`.`ident`, `User`.`parent_name`, `User`.`parent_number`, `User`.`parent_email`, `User`.`squad`, `User`.`squad_leader`, `User`.`ride_along`, `User`.`drivers_license`, `User`.`username`, `User`.`password`, `User`.`department_id`, `User`.`join_date`, `User`.`group_id`, `User`.`test`, (CONCAT(`User`.`first_name`, " ", `User`.`last_name`)) AS `User__name`, `Status`.`id`, `Status`.`status` FROM `admin_cake`.`users` AS `User` LEFT JOIN `admin_cake`.`statuses` AS `Status` ON (`User`.`status_id` = `Status`.`id`) WHERE `User`.`department_id` = 1 ORDER BY `User`.`last_name` ASC LIMIT 15

当使用$this->paginate设置条件时,limit…需要使用函数$this->pagination()。 $this->pagination和$this->Paginator->pagination()不能组合使用

(一)

(二)


为此生成的SQL查询是什么?请确保姓氏没有前导空格。@Drmonkeynija我已经用一个示例查询更新了问题。@InigoFlores我也这么认为,但我似乎找不到任何有额外空格的记录。@Jason您的SQL看起来正确。如果直接在数据库上运行此查询,会得到所需的结果还是不正确?如果查询失败,那么最好将此问题重新编写为MySQL问题,而不是简单的问题。我最初使用了
$this->paginate()
,但将
$this->Paginator->paginate()
与我正在尝试的其他一些问题混在一起。我把它调回原处,得到了同样的结果。
public function index() {
    $this->User->contain('Status');
    $this->paginate = array(
        'limit' => 15,
        'order' => array('User.last_name' => 'DESC'),
        'conditions' => array('User.department_id =' => $this->Session->read('Auth.User.department_id')),
        'contain' => 'Status'
    );
    // Assign settings
    $this->Paginator->settings = $this->paginate;
    $this->set('users', $this->Paginator->paginate());
}
public function index() {
    $this->User->contain('Status');
    $this->paginate = array(
        'limit' => 15,
        'order' => array('User.last_name' => 'DESC'),
        'conditions' => array('User.department_id =' => $this->Session->read('Auth.User.department_id')),
        'contain' => 'Status'
    );
    //Don't use $this->Paginator->paginate()
    $this->set('users', $this->paginate());
}