本文整理汇总了PHP中Cake\Database\Query::modifier方法的典型用法代码示例。如果您正苦于以下问题:PHP Query::modifier方法的具体用法?PHP Query::modifier怎么用?PHP Query::modifier使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Cake\Database\Query
的用法示例。
在下文中一共展示了Query::modifier方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: _selectQueryTranslator
/**
* Modify the limit/offset to TSQL
*
* @param \Cake\Database\Query $query The query to translate
* @return \Cake\Database\Query The modified query
*/
protected function _selectQueryTranslator($query)
{
$skip = false;
$limit = $query->clause('limit');
$offset = $query->clause('offset');
if (isset($query->clause('select')['count'])) {
//TODO instanceof \Cake\Database\Expression\FunctionExpression)
$skip = true;
}
if ($limit && !$offset && !$skip) {
$query->modifier(['_auto_top_' => sprintf('FIRST %d', $limit)]);
}
if ($limit && $offset && !$skip) {
$query->modifier(['_auto_top_' => sprintf('FIRST %d SKIP %d', $limit, $offset)]);
}
if ($skip) {
$query->modifier(['_auto_top_' => '']);
}
return $this->_transformDistinct($query);
}
示例2: _selectQueryTranslator
/**
* Modify the limit/offset to TSQL
*
* @param \Cake\Database\Query $query The query to translate
* @return \Cake\Database\Query The modified query
*/
protected function _selectQueryTranslator($query)
{
$limit = $query->clause('limit');
$offset = $query->clause('offset');
if ($limit && $offset === null) {
$query->modifier(['_auto_top_' => sprintf('TOP %d', $limit)]);
}
if ($offset !== null && !$query->clause('order')) {
$query->order($query->newExpr()->add('(SELECT NULL)'));
}
if ($this->_version() < 11 && $offset !== null) {
return $this->_pagingSubquery($query, $limit, $offset);
}
return $this->_transformDistinct($query);
}