首頁  >  文章  >  php框架  >  laravel學習記錄之強制指定索引進行查詢

laravel學習記錄之強制指定索引進行查詢

藏色散人
藏色散人轉載
2021-11-05 14:20:452549瀏覽

為何必須強制指標為時?

資料庫沒有使用我們所設想的索引進行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(&#39;worked_at&#39;, &#39;<=&#39;, $end)
            ->where(&#39;is_suppose&#39;, 0)
            ->addDomination(&#39;m.statistics-human-view&#39;)
            ->leftJoin(&#39;positions&#39;, &#39;positions.id&#39;, &#39;=&#39;, &#39;agents.position_id&#39;)
            ->get([&#39;worked_days&#39;, &#39;worked_at&#39;]);

【相關推薦:最新的五個Laravel影片教學

以上是laravel學習記錄之強制指定索引進行查詢的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:learnku.com。如有侵權,請聯絡admin@php.cn刪除