thinkPHP 我按照手册使用了 一下 ->order()->limit(1) 怎么都不行?
迷茫
迷茫 2017-04-10 17:59:57
[PHP讨论组]

下面是代码,有一句没问题,只要加上 排序 和限制,就报错?求教为什么?

$stmt=D('classOne');
$db = $stmt->where("id>10")->select();    //这句完全没有问题,
$db =$stmt->where("id>10")->order('id desc')->limit(1)->select();    //这句完出错了?为什么?
echo '<pre>';print_r($db);echo '</pre>';
:(
Call to a member function limit() on null
错误位置
FILE: C:\AppServ\www\yb1\yangbins\Home\Controller\CjdController.class.php  LINE: 68
ThinkPHP3.2.3 { Fast & Simple OOP PHP Framework } -- [ WE CAN DO IT JUST THINK ]

以下是原因:
原来我在 classoneModel.class.php 里多了个:

 function __call($methodname, $args)
    {
        echo "这里是 class shopModel ,你调用的方法{$methodname},参数: (".implode(" , ",$args).')  不存在....<br>';
    }

为什么我没有 覆盖 limit() 和 desc(),只是覆盖了魔术方法,整个文件就出错了??

迷茫
迷茫

业精于勤,荒于嬉;行成于思,毁于随。

全部回复(1)
大家讲道理

这个错误的原因是order()这个方法没有返回Model类本身,在Model代码中这是正确的,看样子是你实例化的classOneModel这个模型里继承覆盖了order()这个方法,并且没有正确的处理它,请检查其中的是不是这么做了。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号