thinkphp查询条件被叠加

在ThinkPHP中,如果一个类的方法被控制器多次调用,可能会遇到查询条件叠加的问题,导致后续查询无法得到预期结果。文章通过示例展示了这个问题,并提出了解决方案,即在每次查询前使用`removeOption(where)`重置条件,确保每个查询的条件独立,从而避免数据查询错误。这提醒开发者在使用框架时需要注意代码的执行逻辑和框架的特性。

有时候,用thinkphp写了一个类,用控制器调用多次,发现条件都叠加起来了

//逻辑类
class Module_article extends Model
{
    ...
    public fucntion article_info($condition=[]){
        $info=Db::name("module_article")->where($condition)->find();
        echo Db::name("module_article")->getLastSql().'<br>';
    }

}

//控制器类调用
class Article extends \think\Controller
{
        ...
        $info1 = $this->article_logic->article_info(['type','eq',1]);
        $info2= $this->article_logic->article_info(['type','eq',2]);
        $this->assign('info1',$info1);
        $this->assign('info2',$info2);

}

以上SQL输出:

select * from article where type =1;

select * from article where type =1 && type=2;

第二个显然不是我们想要的,永远查不到数据。

我们可以通过removeOption('where'),将条件重置为空,逻辑类变成:

//逻辑类
class Module_article extends Model
{
    ...
    public fucntion article_info($condition=[]){
        $info=Db::name("module_article")->removeOption('where')->where($condition)->find();
        echo Db::name("module_article")->getLastSql().'<br>';
    }

}

以上SQL输出:

select * from article where type =1;

select * from article where type=2;

完美解决thinkphp条件叠加的问题,防止查不到数据。

其实TP文档手册已经说了,没有仔细看的就会踩到这个坑。

 

启动代码: <?php // 设置工作目录到项目根目录 chdir(dirname(__DIR__)); // 定义必要的常量 if (!defined('DS')) define('DS', DIRECTORY_SEPARATOR); if (!defined('ROOT_PATH')) define('ROOT_PATH', dirname(__DIR__) . DS); if (!defined('APP_PATH')) define('APP_PATH', ROOT_PATH . 'application' . DS); if (!defined('RUNTIME_PATH')) define('RUNTIME_PATH', ROOT_PATH . 'runtime' . DS); // 防止重复加载 Composer 自动加载文件 if (!class_exists('Composer\Autoload\ClassLoader', false)) { require ROOT_PATH . 'vendor/autoload.php'; } // 加载框架基础文件 require ROOT_PATH . 'thinkphp/base.php'; // 手动加载应用函数文件 if (file_exists(APP_PATH . 'common.php')) { require_once APP_PATH . 'common.php'; } // 设置错误报告级别 error_reporting(E_ALL); ini_set('display_errors', '1'); // 注册自动加载 \think\Loader::register(); // 手动加载采集服务 require_once APP_PATH . 'caiji/CaijiScheduler.php'; require_once APP_PATH . 'caiji/CaijiWorker.php'; try { // 记录启动日志 file_put_contents(RUNTIME_PATH . 'caiji_start.log', date('[Y-m-d H:i:s]') . " 采集服务启动\n", FILE_APPEND); // 创建锁文件 $lockFile = RUNTIME_PATH . 'caiji.lock'; if (file_exists($lockFile)) { exit("采集进程已在运行中\n"); } file_put_contents($lockFile, getmypid()); // 注册关闭函数 register_shutdown_function(function() use ($lockFile) { if (file_exists($lockFile)) { unlink($lockFile); } }); // 启动调度器 $scheduler = new app\caiji\CaijiScheduler(); $scheduler->start(); // 启动Worker $worker = new app\caiji\CaijiWorker(); $worker->start(); } catch (\Throwable $e) { $error = date('[Y-m-d H:i:s]') . " 错误: " . $e->getMessage() . "\n"; $error .= "追踪: " . $e->getTraceAsString() . "\n"; file_put_contents(RUNTIME_PATH . 'caiji_error.log', $error, FILE_APPEND); exit(1); }
05-30
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值