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

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

coldplay.xixi
풀어 주다: 2020-07-01 17:59:47
앞으로
2497명이 탐색했습니다.

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으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿