Heim > PHP-Framework > Laravel > Laravel-Lerndatensätze erzwingen einen angegebenen Index für die Abfrage

Laravel-Lerndatensätze erzwingen einen angegebenen Index für die Abfrage

藏色散人
Freigeben: 2021-11-05 14:20:45
nach vorne
2620 Leute haben es durchsucht

Die Datenbank verwendet nicht den Index, den wir uns für die SQL-Abfrage vorgestellt haben, was zu einer extrem langsamen Abfrage führt.

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

mysql强制索引查询语句

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

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

select * from user where age = 26 force index(age); // Force index
select * from user where age = 26 use index(age); // Priorisieren Sie die Suche nach diesem Index

/**
 * 检测某个表中是否存在某个索引
 * @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);
    }
}
Nach dem Login kopieren

Sie müssen dies im Laravel-Code schreiben:

Verwenden Sie hier die when-Methode, um zu beurteilen Existiert dieser Index? Wenn er nicht vorhanden ist, wird dieser Index nicht verwendet. Andernfalls wird ein Fehler gemeldet, um zu verhindern, dass jemand den Index versehentlich löscht, was dazu führt, dass das System einen Fehler meldet.

Die Anweisung zum Erzwingen der Indizierung lautet hier: 🎜
->from(DB::raw('`erp_agents` FORCE INDEX (`test`)'))
Nach dem Login kopieren
🎜Zum Beispiel: 🎜
$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']);
Nach dem Login kopieren
🎜[Verwandte Empfehlungen: 🎜Die neuesten fünf Laravel-Video-Tutorials🎜]🎜

Das obige ist der detaillierte Inhalt vonLaravel-Lerndatensätze erzwingen einen angegebenen Index für die Abfrage. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:learnku.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage