0
從CakePHP的手冊:CakePHP的遏制和屬於關聯的hasMany條件
Let's say you had a belongsTo relationship between Posts and Authors. Let's say you wanted to find all the posts that contained a certain keyword ("magic") or were created in the past two weeks, but you want to restrict your search to posts written by Bob:
array (
"Author.name" => "Bob",
"OR" => array (
"Post.title LIKE" => "%magic%",
"Post.created >" => date('Y-m-d', strtotime("-2 weeks"))
)
)
然而,它不適合我的工作。我有Scrapes belongsTo Vargroup,Vargroup hasMany Scrape。我的刮傷表有一個字段vargroup_id
當我這樣做:
$this->Vargroup->contain('Scrape');
$this->Vargroup->find('first');
我得到:
Array
(
[Vargroup] => Array
(
[id] => 16950
[item_id] => 1056
[image] => cn4535d266.jpg
[price] => 22.95
[instock] => 1
[timestamp] => 2012-10-29 11:35:10
)
[Scrape] => Array
(
[0] => Array
(
[id] => 18163
[item_id] => 1056
[vargroup_id] => 16950
[timestamp] => 2012-05-23 15:24:31
[instock] => 1
[price] => 22.95
)
)
)
但是當我做:
$this->Vargroup->contain('Scrape');
$this->Vargroup->find('first', array(
'conditions' => array(
'not' => array(
array('Scrape.timestamp >' => $today)
)
)
));
即時得到下面的誤差關聯sql輸出
Warning (512): SQL Error: 1054: Unknown column 'Scrape.timestamp' in 'where clause'
Query: SELECT `Vargroup`.`id`, `Vargroup`.`item_id`, `Vargroup`.`image`, `Vargroup`.`price`, `Vargroup`.`instock`, `Vargroup`.`timestamp` FROM `vargroups` AS `Vargroup` WHERE `Scrape`.`timestamp` = '2012-10-29
它看起來不像它綁定桌子.. 任何幫助,將不勝感激。 感謝
我仍然收到相同的錯誤。雖然我看到你確實修復了一個與額外數組有關的錯誤。謝謝。 –
coukld你給我們更多的信息,如表名,發佈模式等... – Eefret