>데이터 베이스 >MySQL 튜토리얼 >MySQ(Oracle) 퍼지 쿼리를 이해하고 like 대신 instr()을 사용하여 효율성을 높입니다.

MySQ(Oracle) 퍼지 쿼리를 이해하고 like 대신 instr()을 사용하여 효율성을 높입니다.

coldplay.xixi
coldplay.xixi앞으로
2020-07-01 17:59:472496검색

MySQ(Oracle) 퍼지 쿼리를 이해하고 like 대신 instr()을 사용하여 효율성을 높입니다.

like의 효율성이 매우 낮다는 것은 누구나 알고 있으며, 데이터 양이 많으면 매우 느려질 것입니다. 오늘은 like보다 효율적인 내장 함수 instr()을 발견했습니다.

    SELECT * FROM msg_list WHERE title LIKE '%涂山%'
    는 다음으로 대체될 수 있습니다:
  • SELECT * FROM msg_list WHERE INSTR(title,'涂山') > 0

ThinkPHP/Laravel에서 사용되는 메소드는 다음과 같습니다:

    네이티브 INSTR()을 실행하려면 whereRaw()를 사용하세요.
  1. 생성자 쿼리를 수정합니다(권장하지는 않지만 사용하기 편리함)
    项目根目录\thinkphp\library\think\db\Builder.php

  2. MsgList::where([
         'title' => ['instr','涂山']])
     ->select();
관련 학습 권장사항:

mysql 비디오 튜토리얼

위 내용은 MySQ(Oracle) 퍼지 쿼리를 이해하고 like 대신 instr()을 사용하여 효율성을 높입니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 learnku.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제