加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

逃离CakePHP Paginate条件

发布时间:2020-12-13 16:09:45 所属栏目:PHP教程 来源:网络整理
导读:分页查询: $this-paginate = array( 'conditions' = array( // 'Product.soft_delete NOT' = 'on',// 'Product.product_status NOT' = 'inactive',// $conditions 'Product.original_price =' = 77 ),'recursive' = 2,// 'order' = $sort_by,'paramType' =
分页查询:

$this->paginate = array(
            'conditions' => array(
               // 'Product.soft_delete NOT'    => 'on',// 'Product.product_status NOT' => 'inactive',// $conditions
               'Product.original_price <=' =>  77
            ),'recursive'  => 2,// 'order'      => $sort_by,'paramType'  => 'querystring','limit'      => '25','maxLimit'   => 100,);
        $records = $this->paginate('Product');

CakePHP将单引号添加到original_price 77,因此它在数字比较中产生问题.

Cakephp查询输出:

............LEFT JOIN `admin_mytab`.`seller_categories` AS `Seller_3` ON (`Product`.`seller_3` = `Seller_3`.`id`) WHERE `Product`.`original_price` <= '77' LIMIT 25

MySQL original_price是varchar字段. 77引号无法与mysql字段进行比较.

任何帮助,将不胜感激.

解决方法

尝试这样写:

$this->paginate = array(
    'conditions' => array(
        'Product.original_price <= 77'
    ),'recursive' => 2,'paramType' => 'querystring','limit' => '25','maxLimit' => 100,);
$records = $this->paginate('Product');

而不是key =>价值只是使用价值.但通常,如果用引号括起数字也无关紧要,即使使用varchar也是如此.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读