Compatibilité MySQL + suppression de Redis comme dépendance requise
DbCompat (app/Support/DbCompat.php) : - like() → ilike (pgsql) ou like (mysql) - jsonRegexRaw() → data::text ~* ? (pgsql) ou CAST(data AS CHAR) REGEXP ? (mysql) - ftsRaw() → to_tsvector/plainto_tsquery (pgsql) ou null/fallback LIKE (mysql) - generatedJsonCol() → syntaxe colonne générée JSON selon le SGBD - generatedJsonNestedCol() → idem pour champs imbriqués Migrations : - create_releves_table : JSON/JSONB selon SGBD, colonnes générées adaptées, index GIN uniquement pour PostgreSQL Controllers : - LieuController (search + index) : ilike → DbCompat::like() - Admin\UserController (index) : ilike → DbCompat::like() - RechercheController : FTS + regex → DbCompat, fallback LIKE MySQL - ExportController : regex → DbCompat::jsonRegexRaw() UpdateService : - backupDatabase() : pg_dump (pgsql) ou mysqldump (mysql) - restoreBackup() : psql (pgsql) ou mysql (mysql) Docker : - docker-compose.yml : suppression Redis (plus requis) - docker-compose.mysql.yml : nouveau fichier pour dev MySQL - docker-compose.prod.yml : suppression Redis, DB_IMAGE configurable, CACHE_STORE/SESSION_DRIVER/QUEUE_CONNECTION → database par défaut .env.example : - DB_PORT commenté avec les deux valeurs (5432/3306) - CACHE_STORE et QUEUE_CONNECTION commentés (database par défaut) - Redis marqué optionnel Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -6,6 +6,7 @@ use App\Http\Requests\StoreLieuRequest;
|
||||
use App\Http\Requests\UpdateLieuRequest;
|
||||
use App\Models\Lieu;
|
||||
use App\Models\LieuType;
|
||||
use App\Support\DbCompat;
|
||||
use Illuminate\Http\JsonResponse;
|
||||
use Illuminate\Http\RedirectResponse;
|
||||
use Illuminate\Http\Request;
|
||||
@@ -20,9 +21,9 @@ class LieuController extends Controller
|
||||
|
||||
$lieux = Lieu::with('lieuType')
|
||||
->where(function ($query) use ($q) {
|
||||
$query->where('nom_long', 'ilike', "%{$q}%")
|
||||
->orWhere('nom', 'ilike', "%{$q}%")
|
||||
->orWhere('code', 'ilike', "%{$q}%");
|
||||
$query->where('nom_long', DbCompat::like(), "%{$q}%")
|
||||
->orWhere('nom', DbCompat::like(), "%{$q}%")
|
||||
->orWhere('code', DbCompat::like(), "%{$q}%");
|
||||
})
|
||||
->orderBy('nom_long')
|
||||
->limit(25)
|
||||
@@ -49,9 +50,9 @@ class LieuController extends Controller
|
||||
if ($request->filled('q')) {
|
||||
$q = trim($request->get('q'));
|
||||
$query->where(function ($wq) use ($q) {
|
||||
$wq->where('nom_long', 'ilike', "%{$q}%")
|
||||
->orWhere('nom', 'ilike', "%{$q}%")
|
||||
->orWhere('code', 'ilike', "%{$q}%");
|
||||
$wq->where('nom_long', DbCompat::like(), "%{$q}%")
|
||||
->orWhere('nom', DbCompat::like(), "%{$q}%")
|
||||
->orWhere('code', DbCompat::like(), "%{$q}%");
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user