千家信息网

laravel怎么强制指定索引进行查询

发表于:2024-11-17 作者:千家信息网编辑
千家信息网最后更新 2024年11月17日,本篇内容介绍了"laravel怎么强制指定索引进行查询"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
千家信息网最后更新 2024年11月17日laravel怎么强制指定索引进行查询

本篇内容介绍了"laravel怎么强制指定索引进行查询"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

为什么需要强制索引?

数据库没有使用我们设想的索引进行sql查询,导致查询特别慢。

mysql强制索引查询语句

  • select * from user where age = 26 force index(age); // 强制索引

  • select * from user where age = 26 use index(age); // 优先按照这种索引查找

/** * 检测某个表中是否存在某个索引 * @param $table * @param $index * @return bool * @author zhaohao * @date 2019-08-26 17:42 */if(!function_exists('hasIndex')) {    function hasIndex($table, $name)    {        $conn = IlluminateSupportFacadesSchema::getConnection();        $dbSchemaManager = $conn->getDoctrineSchemaManager();        $doctrineTable = $dbSchemaManager->listTableDetails($table);        return $doctrineTable->hasIndex($name);    }}
  • 在laravel的代码里面需要这样写:

在这里用when方法来判断此索引是否存在,日过不存在的话就不用这个索引,不然会报错,避免有人误删索引后,导致系统报错。

此处强制索引的语句是:

->from(DB::raw('`erp_agents` FORCE INDEX (`test`)'))

例如:

$agents = Agent::where($whereType)            ->when(hasIndex('Agent', 'test'),function ($q){                $q->from(DB::raw('`erp_agents` FORCE INDEX (`test`)'));            })            ->when(request('position',false),function ($q){                $q->whereIn('position_id',request('position'));            })            ->whereIn('agents.status', $validStatus)            ->where('worked_at', '<=', $end)            ->where('is_suppose', 0)            ->addDomination('m.statistics-human-view')            ->leftJoin('positions', 'positions.id', '=', 'agents.position_id')            ->get(['worked_days', 'worked_at']);

"laravel怎么强制指定索引进行查询"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!

索引 强制 查询 内容 更多 知识 语句 实用 学有所成 接下来 不用 代码 困境 实际 情况 数据 数据库 文章 方法 案例 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 数据库安全性实验报告结论 ug完全加载特征数据库 办公系统软件开发机构 网络安全信息化会议重要讲话 武汉百里半网络技术 广电 网络安全 存在 问题 电脑输入网络安全密钥不显示 软件开发人员工作规范 网络安全的三个目标 广州微革网络技术有限公司 全应科技工业互联网方案商 什么是客户机与web服务器通信 如何选择服务器联机明日之后 计算机网络技术专业对口高考 ssh服务器配置 数据库字段缓存 贵州信息安全学习网络安全 镇海软件开发商 软件开发vt环境是什么 网络安全都讲什么内容 我的世界云服务器防火墙 本地存档覆盖服务器存档 条件查询数据库表sql 什么是机器学习的数据库 广东浪潮服务器维修调试哪家便宜 宿州网络安全支队长 珠海海岸线软件开发 网络安全公益广告宣传工作 昆明教育网络安全教育片 数据库外码谁参照谁
0