- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有两个模型,listings 和 bookings。房源有很多预订。我正在尝试编写查询以返回在特定时间段内没有预订的所有列表。
到目前为止我已经了解了,但我仍然是 cakephp 的新手,而且我的 sql 也不是很好。在我的 Controller 方法中我有
$conditions = array(
"OR" => array(
"Listing.address_one LIKE" => "%".$area."%",
"Listing.address_two LIKE" => "%".$area."%",
"Listing.city LIKE" => "%".$area."%",
"Listing.postcode LIKE" => "%".$area."%",
"Listing.title LIKE" => "%".$area."%",
)
);
$this->paginate = array(
'conditions'=> $conditions,
'joins'=>array(
array(
'table'=>'bookings',
'alias'=>'Booking',
'type' =>'inner',
'conditions' =>array('Booking.listing_id = Listing.id', 'Booking.checkin NOT BETWEEN ? AND ?' => array($to, $from))
)
),
'limit' => 10,
);
$data = $this->paginate();
这只会获取所有实际与预订相关联的列表。不仅如此,它还不会忽略在给定时间段内预订的任何预订。
它创建的 SQL 是:
SELECT
...
FROM
`database`.`listings` AS `Listing`
INNER JOIN
`database`.`bookings` AS `Booking` ON (
`Booking`.`listing_id` = `Listing`.`id` AND
`Booking`.`checkin` NOT BETWEEN '18-07-2013' AND '10-07-2013'
)
LEFT JOIN
`database`.`users` AS `User` ON (
`Listing`.`user_id` = `User`.`id`
)
WHERE (
(`Listing`.`address_one` LIKE '%belfast%') OR
(`Listing`.`address_two` LIKE '%belfast%') OR
(`Listing`.`city` LIKE '%belfast%') OR
(`Listing`.`postcode` LIKE '%belfast%') OR
(`Listing`.`title` LIKE '%belfast%')
)
LIMIT 10
这看起来有点正确(?)但显然不是。有人有什么想法吗?谢谢
最佳答案
return all listings who DON'T have bookings booked during a certain time period
生成适当查找的第一步是了解所需的查询类型 - 即从数据库开始。
问题中的查询正在查找预订超出日期范围的所有列表(匹配条件)。 IE。在任何时间预订贝尔法斯特,BETWEEN '18-07-2013' AND '10-07-2013'
除外。这和上面那句话的逻辑不一样。
有多种方法可以实现,这里按易用性顺序列出两种:
SELECT
*
FROM
`nights2stay`.`listings` AS `Listing`
LEFT JOIN # <-
`nights2stay`.`bookings` AS `Booking` ON (
`Booking`.`listing_id` = `Listing`.`id` AND
`Booking`.`checkin` BETWEEN '18-07-2013' AND '10-07-2013' # <-
)
LEFT JOIN
`nights2stay`.`users` AS `User` ON (
`Listing`.`user_id` = `User`.`id`
)
WHERE
(
(`Listing`.`address_one` LIKE '%belfast%') OR
(`Listing`.`address_two` LIKE '%belfast%') OR
(`Listing`.`city` LIKE '%belfast%') OR
(`Listing`.`postcode` LIKE '%belfast%') OR
(`Listing`.`title` LIKE '%belfast%')
) AND
`Booking`.`id` IS NULL # <-
LIMIT 10
即加入日期与日期范围匹配的预订,并且只返回没有预订的记录。
实现上面的查询很容易:
function index() {
... # Existing code
$this->paginate['joins'][0]['type'] = 'LEFT';
$this->paginate['conditions']['Booking.id'] = null;
$data = $this->paginate();
$this->set('data', $data);
}
或者,使用 NOT EXISTS :
SELECT
*
FROM
`nights2stay`.`listings` AS `Listing`
# <
LEFT JOIN
`nights2stay`.`users` AS `User` ON (
`Listing`.`user_id` = `User`.`id`
)
WHERE
(
(`Listing`.`address_one` LIKE '%belfast%') OR
(`Listing`.`address_two` LIKE '%belfast%') OR
(`Listing`.`city` LIKE '%belfast%') OR
(`Listing`.`postcode` LIKE '%belfast%') OR
(`Listing`.`title` LIKE '%belfast%')
) AND
NOT EXISTS ( # <
SELECT # <
* # <
FROM # <
`nights2stay`.`bookings` AS `Booking` # <
WHERE # <
`Booking`.`listing_id` = `Listing`.`id` AND # <
`Booking`.`checkin` BETWEEN '18-07-2013' AND '10-07-2013' # <
) # <
LIMIT 10
这种查询更合乎逻辑,好处是它是一个有意义的查询“在没有 (...) 的地方找到这些”。它可能性能更好,但对于任何查询,最好在选择一个或另一个之前分析/解释查询。
实现上面的查询is a little more involved in CakePHP但这并不难:
function index() {
...
$db = $this->Listing->getDatasource();
$subQuery = $db->buildStatement(array(
'fields' => "*",
'table' => $db->fullTableName('bookings'),
'alias' => 'Booking'
'conditions' => array(
'`Booking`.`listing_id` = `Listing`.`id`',
"`Booking`.`checkin` BETWEEN '$to' AND '$from'"
)
));
$expression = $db->expression('NOT EXISTS (' . $subQuery . ')');
$this->paginate['conditions'][] = $expression;
$data = $this->paginate();
$this->set('data', $data);
}
关于php - 在 cakephp 中查询所需的 mySql 建议,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17537009/
我有一个依赖于包 B 的包 A。当包 A 中的代码运行并访问包 B 中的类时,包 B 的状态将被解析 (4),而不是 Activity (32) 和包 B 的激活器也没跑好。我认为 bundle B
这个问题在这里已经有了答案: How to remove the space between inline/inline-block elements? (41 个回答) 关闭 7 年前。
我正在尝试使用 Java OpenAL 库。我在导入名为 libsoft_oal.so 的 native 库时遇到问题。 Java OpenAL 依赖于 OpenAL 软实现。我尝试根据他们在 git
我正在尝试启动我的应用程序。是一个 unicorn +工头+sinatra的应用。 这是我的 config.ru 文件: require "rubygems" require "sinatra" Bu
我有一个下拉列表,其中包含一些从数据库表中检索的值,我想要的是当单击按钮时它应该只获得选项标签的中间值,但只有那些类名为“get_this”的选项标签并离开那些选项,如果他们没有这个类 预期输出:值
我有一个index.php文件,需要一个通用的head.php文件,head.php文件中有几个Javascript文件,当这样尝试时,代码在源代码中看起来很好,但文件却不是实际上对文档做任何事情。
有人能帮帮我吗? 我已经像这样运行了 imsmod: $ insmod /data/mm/mmdev.ko epoll_rate=100 但是我得到一个错误: insmod: init_module
是否有键盘快捷键或插件可以在 Notepad++ 中打开 PHP 所需或包含的文件?我知道,在 Dreamweaver 中,执行此操作的命令是 Ctrl+D,但我似乎无法在 Notepad++ 中找到
我已经用 js 设置了一个显示/隐藏 div,但我很难弄清楚如何一次显示一个 div。目前发生的情况是,除非我再次单击原始链接来关闭该 div,否则每个 div 都会显示。 http://www.li
当我尝试将未分配的辅助分片分配给节点时出现错误。 { "error": { "root_cause": [ { "type": "remote_transpor
我正在构建一个 C++ 应用程序,使用 Netbeans 6.9 作为我的 IDE。我有一个 C++ 库,它是一个纯 C 库的包装器。 我已将文件正确添加到项目中(使用添加库文件选项)。这是 g++
我是一名优秀的程序员,十分优秀!