CakePHP - сортировка с использованием поля таблицы соединений HABTM - PullRequest
4 голосов
/ 15 мая 2010

вот моя проблема:

Таблица 1: Сообщения

id - int
title - varchar

Таблица2: Категории

id - int
name - varchar

HABTM JoinTable: category_posts

id - int
post_id - int
category_id - int
postorder - int

Как видите, в объединяющей таблице есть поле под названием «postorder» - это для заказа постов в определенной категории. Например,

Posts: Post1, Post2, Post3, Post4
Categories: Cat1, Cat2
Ordering:
     Cat1 - Post1, Post3, Post2
     Cat2 - Post3, Post1, Post4

Сейчас в CakePHP,

$postpages = $this->Post->Category->find('all');

дает мне массив, подобный

Array
(
  [0] => Array
    (
      [Category] => Array
        (
          [id] => 13
          [name] => Cat1
        )
        [Post] => Array
        (
          [0] => Array
          (
            [id] => 1
            [title] => Post2
            [CategoriesPost] => Array
            (
              [id] => 17
              [post_id] => 1
              [category_id] => 13
              [postorder] => 3
            )
          )
          [1] => Array
          (
            [id] => 4
            [title] => Post1
            [CategoriesPost] => Array
            (
              [id] => 21
              [post_id] => 4
              [category_id] => 13
              [postorder] => 1
            )
          )

        )
    )
) 

Как видите [Post], они не упорядочены в соответствии с [CategoriesPost] .postorder, а упорядочены в соответствии с [CategoriesPost] .id. Как я могу получить массив, упорядоченный в соответствии с [CategoriesPost] .postorder?

Заранее спасибо за ваше время:)

Обновление 1: Запросы из журнала SQL Cake:

SELECT `Category`.`id`, `Category`.`name` FROM `categories` AS `Category` WHERE 1 = 1

SELECT `Post`.`id`, `Post`.`title`, `CategoriesPost`.`id`, `CategoriesPost`.`post_id`, `CategoriesPost`.`category_id`, `CategoriesPost`.`postorder` FROM `posts` AS `Post` JOIN `categories_posts` AS `CategoriesPost` ON (`CategoriesPost`.`category_id` IN (13, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52) AND `CategoriesPost`.`post_id` = `Post`.`id`) 

Я ищу, как сделать так, чтобы торт помещал Order By CategoriesPost.postorder во второй запрос SELECT SQL.

Обновление 2: Пытаясь использовать порядок следующим образом

$this->Post->Category->find('all',array('order'=>array('postorder'=>'ASC')));

выдает ошибку SQL

SQL Error: 1054: Unknown column 'PostsCategory.postorder' in 'order clause'

SQL-запрос

SELECT `Category`.`id`, `Category`.`name` FROM `categories` AS `Category` WHERE 1 = 1 ORDER BY `CategoriesPost`.`postorder` ASC

Вместо ORDERBY во втором запросе SQL (в моем обновлении 1) его выполнение выполняется в первом запросе SQL, как показано выше.

1 Ответ

4 голосов
/ 15 мая 2010

Попробуйте сделать его частью ассоциации:

var $hasAndBelongsToMany = array(
    'Post' => array(
        ...
        'order' => 'CategoriesPost.postorder DESC',
    )
)

Это может работать, а может и не работать, не проверял.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...