From eadaa83dbbcacb85522d36024b9f2aee5d617f1c Mon Sep 17 00:00:00 2001 From: Ivan Vermeyen Date: Sat, 4 Feb 2023 17:39:52 +0100 Subject: [PATCH] Support PostgreSQL case insensitive queries with ILIKE (#24) --- src/UniqueTranslationValidator.php | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/src/UniqueTranslationValidator.php b/src/UniqueTranslationValidator.php index 13c090f..9d7f4f5 100644 --- a/src/UniqueTranslationValidator.php +++ b/src/UniqueTranslationValidator.php @@ -234,10 +234,13 @@ protected function findTranslation($connection, $table, $column, $locale, $value $escaped = DB::getDriverName() === 'sqlite' ? '\\\\' : '\\\\\\\\'; $value = str_replace('\\', $escaped, $value); + // Support PostgreSQL case insensitive queries with ILIKE + $operator = DB::getDriverName() === 'pgsql' ? 'ILIKE' : 'LIKE'; + return DB::connection($connection)->table($table) - ->where(function ($query) use ($column, $locale, $value) { - $query->where($column, 'LIKE', "%\"{$locale}\": \"{$value}\"%") - ->orWhere($column, 'LIKE', "%\"{$locale}\":\"{$value}\"%"); + ->where(function ($query) use ($column, $operator, $locale, $value) { + $query->where($column, $operator, "%\"{$locale}\": \"{$value}\"%") + ->orWhere($column, $operator, "%\"{$locale}\":\"{$value}\"%"); }); }