Laravel では、ファジークエリを実行する必要がよくありますが、クエリ結果に重複データが含まれていないことを望みます。この記事では、Laravel のクエリ ビルダーを使用してファジー クエリと重複排除操作を実装する方法について説明します。
1. ファジークエリ
Laravel のクエリコンストラクターは、ファジークエリを簡単に実装するための柔軟なメソッドを多数提供します。一般的なファジー クエリ メソッドのいくつかを次に示します。
同様のメソッドを使用して、基本的なファジー クエリを実装します。たとえば、キーワード「laravel」を含むすべての記事をクエリする必要があるとします。
$articles = DB::table('articles') ->where('content', 'like', '%laravel%') ->get();
この例では、where メソッドを使用して、content
フィールドにキーワードが含まれるという条件を指定します。 "laravel"、そして like 演算子を使用してファジークエリを実装します。 %
記号は任意の文字と一致するために使用されることに注意してください。
orWhere メソッドを使用して、複数条件のあいまいクエリを実装します。たとえば、キーワード「laravel」または「php」を含むすべての記事をクエリする必要があるとします。
$articles = DB::table('articles') ->where('content', 'like', '%laravel%') ->orWhere('content', 'like', '%php%') ->get();
この例では、where メソッドを使用して最初の条件を content## として指定します。 # フィールドにはキーワード「laravel」が含まれており、orWhere メソッドを使用して、2 番目の条件が
content フィールドにキーワード「php」が含まれていることであることを指定します。
$articles = DB::table('articles') ->whereRaw('content REGEXP "[0-9]+"') ->get();
content であることを指定します。フィールドは、正規表現
[0 -9] 、つまり、少なくとも 1 つの数値が含まれています。
$articles = DB::table('articles') ->select('title', 'content') ->distinct() ->where('content', 'like', '%laravel%') ->get();
title## であることを指定します。 # と content
を指定し、distinct メソッドを使用して重複排除操作を指定します。個別のメソッドを使用すると、すべてのフィールドがクエリされ、重複する値が削除されることに注意してください。
$articles = DB::table('articles') ->select('author', 'title', 'content') ->where('content', 'like', '%laravel%') ->groupBy('author', 'title', 'content') ->get();
この例では、select メソッドを使用して、返される記事を指定します。
author、title
、content
のフィールドを設定し、groupBy メソッドを使用して author
、title# の順序を指定します。 ## と
content をグループ化します。 groupBy メソッドを使用すると、指定されたフィールドによって一致する結果セットがグループ化されるため、結果セットが不正確になり、一部のデータが返されなくなる可能性があることに注意してください。
つまり、Laravel のクエリ ビルダーを使用すると、ファジー クエリと重複排除操作を簡単に実装でき、クエリの効率と結果セットの精度を大幅に向上させることができます。
以上がlaravelでファジークエリと重複排除を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。