Idempotent insert med SELECT ... WHERE NOT EXISTS
Importer startdata uten deprecated VALUES()-bruk.
SQL
Copy
Forutsetninger
MySQL 8.0.41+, tilgang til testdata og mulighet til å kjøre EXPLAIN ANALYZE.
Idempotent insert med SELECT ... WHERE NOT EXISTS
Importer startdata uten deprecated VALUES()-bruk.
Når bør du bruke scriptet?
Dette scriptet passer når du vil løse én konkret oppgave raskt, men fortsatt holde kvaliteten høy nok til at koden tåler å bli flyttet inn i produksjonsflyt senere.
Hvorfor er dette nyttig i WEBoracle?
WEBoracle kombinerer innhold, adminverktøy og backendflyt. Små, fokuserte scripts gjør det mulig å bygge funksjoner stegvis uten å blande alt inn i samme fil.
Kode
INSERT INTO roles (role_id, role_name)
SELECT 4, 'premium_administrator'
WHERE NOT EXISTS (
SELECT 1 FROM roles WHERE role_id = 4
);
Tilpasning
- Bytt ut hardkodede navn og tabeller før produksjon.
- Legg til logging hvis scriptet kjører i adminnære eller sikkerhetskritiske løp.
- Pakk logikken inn i en tjeneste eller modul når du ser at den blir gjenbrukt.
Kode
INSERT INTO roles (role_id, role_name)
SELECT 4, 'premium_administrator'
WHERE NOT EXISTS (
SELECT 1 FROM roles WHERE role_id = 4
);