Dotazy Laravel kde LIKE, před a po Laravel 11/12

Dotazy typu Where LIKE v systému Laravel Při práci s databázemi v Laravelu je jednou z nejčastějších potřeb vyhledávání záznamů pomocí příkazu SQL LIKE klauzule. To umožňuje prová...

Světlý režim slouží jen pro ukázku funkcionality. Proto používejte tmavou verzi webu.

30. 09. 2025

Dotazy Laravel kde LIKE, před a po Laravel 11/12

Dotazy typu Where LIKE v systému Laravel

Při práci s databázemi v Laravelu je jednou z nejčastějších potřeb vyhledávání záznamů pomocí příkazu SQL LIKE klauzule. To umožňuje provádět částečné shody - například vyhledat všechny uživatele, jejichž jména začínají na "John".

V tomto příspěvku prozkoumáme, jak používat where like dotazy v systému Laravel, jak to fungovalo před Laravelem 11 a 12 a co se v těchto novějších verzích změnilo. Budeme se také zabývat dotazy LIKE nerozlišující velká a malá písmena, dotazy LIKE s více sloupcia novější whereAny / whereAll / whereNone doložky.

Použití LIKE v Laravelu před verzemi 11 a 12

Před verzemi Laravel 11 a 12 bylo nutné použít příkaz where metoda s LIKE obsluha ručně:

// Find users whose names start with "John"
$users = User::where('name', 'LIKE', 'John%')->get();
 
// Find users whose email contains "gmail"
$users = User::where('email', 'LIKE', '%gmail%')->get();

Použití whereLike v Laravel 11 a 12

Z Laravel 11 a 12, Eloquent představil výraznější whereLike a orWhereLike syntaxe:

// Find users whose names start with "John"
$users = User::whereLike('name', 'John%')->get();
 
// Find users whose email contains "gmail"
$users = User::whereLike('email', '%gmail%')->get();

Dotazy LIKE nerozlišující velká a malá písmena

Rozlišování malých a velkých písmen u dotazů LIKE závisí na tom, zda je v databázi použita funkce collation. Například MySQL utf8mb4_unicode_ci sjednocení je rozlišování velkých a malých písmen ve výchozím nastavení.

Pokud chcete výslovně vynutit nerozlišuje velká a malá písmena jako dotazy, můžete použít LOWER():

// Case insensitive search for "john"
$users = User::whereRaw('LOWER(name) LIKE ?', ['%john%'])->get();

Nebo ji zkombinujte s novou whereLike:

$users = User::whereLike(DB::raw('LOWER(name)'), '%john%')->get();

Dotazy LIKE na více sloupců

Někdy chcete hledat napříč více sloupců, jako je jméno or e-mail.

Před Laravelem 11 a 12:

$users = User::where('name', 'LIKE', '%john%')
->orWhere('email', 'LIKE', '%john%')
->get();

Od verze Laravel 11 a 12:

$users = User::whereAny(['name', 'email'], 'LIKE', '%john%')->get();
 
$users = User::whereAll(['name', 'email'], 'LIKE', '%john%')->get();

Souhrn

  • Před Laravelem 11 a 12: Použijte where('column', 'LIKE', 'pattern').
  • Laravel 11 a 12+: Použijte whereLike a orWhereLike pro čistší syntaxi.
  • Nerozlišuje velká a malá písmena: Použijte LOWER() s nezpracovanými dotazy, pokud se nerozlišují velká a malá písmena.
  • Více sloupců: Použijte whereAny(['col1', 'col2'], 'LIKE' 'pattern').
  • Pokročilé: Použijte whereAny, whereAlla whereNone pro vícesloupcové dotazy LIKE s logikou OR, AND nebo NOT.

Původní článek publikoval Nabil Hassen.

Mohlo by vám pomoct

Praktické věci kolem webu

Než se pustíte do webu, hodí se mít jasno v podkladech, WordPressu, cookies a měření.

Google reference

Co říkají klienti

Ukázky skutečných recenzí, které klienti zanechali na mém Google profilu.

Přejít na recenze
★ ★ ★ ★ ★

„Člověk, který své práci a rozumí a ví co dělá. Velmi rychlá komunikace a profesionální přístup. Doporučuji.“

Jaroslav Kupča
Google
★ ★ ★ ★ ★

„Skvělá spolupráce, při dalších projektech určitě nebudu shánět někoho jiného.“

Roman Koňařík
Google
★ ★ ★ ★ ★

„S panem Vančurou jsem spolupracovala na tvorbě mých webových stránek a jsem maximálně spokojená. Oceňuji profesionální přístup, rychlou komunikaci a schopnost přesně pochopit moje představy. Web je moderní, přehledný, funkční a skvěle vypadá i na mobilu. Celý proces proběhl hladce, s jasným vysvětlením jednotlivých kroků a výborným výsledkem. Určitě doporučuji každému, kdo hledá spolehlivý a kvalitní přístup.“

Barbora Zemánková
Google
★ ★ ★ ★ ★

„Spolupráce při tvorbě konfigurátoru proběhla naprosto bez problémů. Oceňuji profesionální přístup, rychlou komunikaci a schopnost pochopit specifický projekt od A do Z. Konfigurátor je přehledný, funkční a přesně odpovídá mým požadavkům. Rozhodně doporučuji.“

mareksevcik_FPV
Google
★ ★ ★ ★ ★

„Velmi dobrá a rychlá spolupráce. Doporučuji!“

Leoš Kaucký
Google
★ ★ ★ ★ ★

„Přesně takto si představujeme profesionální práci. Dekujeme“

STAVILLI
Google
★ ★ ★ ★ ★

„Ať už se jedná o optimalizaci webu, nebo tvorbu na míru oceňuji kromě profesionální práce a znalostí problematiky také férový přístup a komunikaci.“

Aleš Illický
Google
★ ★ ★ ★ ★

„Děkuji za profesionální spolupráci, vše dle domluvy, naprostá spokojenost a mohu jen vřele doporučit.... Při dalších projektech určitě opět využiji Vašich služeb“

Peter Spilak
Google
★ ★ ★ ★ ★

„Profesionalita a velká ochota, nemohu jinak než doporučit“

Magdalena Vašková
Google
★ ★ ★ ★ ★

„Skvělá zkušenost při tvorbě webu, profesionální přístup, rychlost, ochota pomoci“

Jana Kono
Google
★ ★ ★ ★ ★

„Rychlá spolupráce a komunikace – mohu jen doporučit.“

Gawix
Google
★ ★ ★ ★ ★

„Moc mi pomohl, když jsem potřebovala pomoc s webem. A bylo to gratis :)). Jsem mu neskonale vděčná.“

Radka Arbesová
Google
★ ★ ★ ★ ★

„Děkuji Jiřímu za rychlou a kvalitní spolupráci na tvorbě webu. Srozumitelná a ochotná komunikace mě vždycky potěší a přináší důvěru.“

Jiří Mařík
Google
★ ★ ★ ★ ★

„Jsem maximálně spokojená. Rychlost, ochota a cenově dostupné. Děkuji“

Veronika Černá
Google
★ ★ ★ ★ ★

„Naprostá spokojenost. Rychlá komunikace, skvělá cena a odborná pomoc. Moc děkuji :)“

Patricie Kučerová
Google
★ ★ ★ ★ ★

„Velká spokojenost, rychlost a p. Vančura moc dobře ví co dělá. :)“

Ondřej Daniško
Google
★ ★ ★ ★ ★

„dobrá práce, rychlá odezva“

Zuzana Jírová
Google
★ ★ ★ ★ ★

„S programátory mám zkušeností hodně, ale tady musím opravdu pochválit. Pro mě a mé přátele vytvořil skvělý nástroj na evidenci sbírek a opravdu se to povedlo. Bylo to hotové rychle, kvalitně a za skvělou cenu. Komunikace funguje velmi rychle, což je super a ne úplně standard. Díky za super práci, za mě 100% spokojenost!“

Zdeněk
Google
★ ★ ★ ★ ★

„Vše bylo rychlé a hlavně to funguje. Dobrá práce.“

Lukáš Bartášek
Google
★ ★ ★ ★ ★

„Normálně recenze nepíši, ale zde rád doporučím kvalitní práci. Jiří pro mě vytvořil web pro dětské tábory. Kvalitní práce, rychlá komunikace a vlastní nápady, které Jiří sám přidá, jsou na velice vysoké úrovni. Nemohu hodnotit jinak než 5/5.“

Tomáš Loněk
Google
★ ★ ★ ★ ★

„Pan Jiri nam delal jiz 3 webove stranky a vzdy velka spokojenost, je mega rychly a vse hned kladne vyridi, mohu pouze doporucit. Poradi si bez problemu i s rezervacnimi kalendaremi, udrzbou socialnich siti, atd.“

Barbara Mašková
Google