force index 用ORM如何书写?

1. 运行环境

Laravel 版本:Laravel Framework 5.7.29

PHP 版本:PHP 7.1.12

CentOS 8

2. 问题描述?

业务需要强制指定索引,sql代码如下,但ORM方式我没有找到如何指定,有没有大神知道

select count(*)  FROM tb_user force index (update_at) 
WHERE update_at BETWEEN 1641830400 and 1641916799 and type=4;

3. 您期望得到的结果?

以上sql的Laravel Query Builder写法

orm
世界最好语言的追随者
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
最佳答案

可以创建一个scope来处理这类情况,如下:

use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Support\Facades\DB;

Class SomeModel extends Model {
    public function scopeForceIndex(Builder $query, string $index): Builder
    {
        $table = $this->getTable();
        return $query->from(DB::raw("`$table` FORCE INDEX(`$index`)"));
    }
}

调用:

SomeModel::forceIndex('custormer_index')->get();
3年前 评论
renxiaotu (楼主) 3年前
讨论数量: 3

可以创建一个scope来处理这类情况,如下:

use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Support\Facades\DB;

Class SomeModel extends Model {
    public function scopeForceIndex(Builder $query, string $index): Builder
    {
        $table = $this->getTable();
        return $query->from(DB::raw("`$table` FORCE INDEX(`$index`)"));
    }
}

调用:

SomeModel::forceIndex('custormer_index')->get();
3年前 评论
renxiaotu (楼主) 3年前

可以创建一个scope来处理这类情况,如下:

use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Support\Facades\DB;

Class SomeModel extends Model {
    public function scopeForceIndex(Builder $query, string $index): Builder
    {
        $table = $this->getTable();
        return $query->from(DB::raw("`$table` FORCE INDEX(`$index`)"));
    }
}

调用:

SomeModel::forceIndex('custormer_index')->get();
3年前 评论
renxiaotu (楼主) 3年前
pndx

这个厉害

3年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!