Welkom bij de Tweaking4All gemeenschapsforums!
Voor je gaat deelnemen, bekijk de Forum Regels!
Specifieke onderwerpen: Start het onderwerp met de naam van het programma of systeem.
Bijvoorbeeld “MacOS X – Jouw vraag“, of bijvoorbeeld “MS Word – Jouw Tip of Truc“.
Merk op: Omschakelen naar een andere taal zal niet werken als je een post aan het lezen bent aangezien er waarschijnlijk geen vertaling beschikbaar is.
[Opgelost] SQLite - Voorkomen van NULL returns (COALESCO)
(@hans)
Famed Member Admin
Deelgenomen: 12 jaar geleden
Berichten: 2859
Topic starter
30 januari 2020 15:14
Soms kan een SELECT een NULL waarde teruggeven, b.v. in een query zoals deze waarbij geen records werden gevonden in de subquery:
SELECT (SELECT someid FROM sometable WHERE somevalue=something) ...
Als jouw applicatie de return waarde dan om wil zetten naar b.v. een nummer (integer) dan kon je weleens de foutmelding krijgen- "" not an Integer;
Na wat zoek werk vond ik een handige oplossing in de functie COALESCE welke een aantal waarden (variable) neemt, en daarvan de eerste terug geeft die geen NULL is (tenzij alle waarden NULL zijn).
Dus COALESCE(NULL. NULL, 1, 2, NULL) levert "1", en COALESCE(NULL,"a","b") levert "a".
Stel we willen in ons voorbeeld minstens een '0' terug krijgen dan kunnen we dat zo doen:
SELECT COALESCE( (SELECT someid FROM sometable WHERE somevalue=something), 0) ...
Dus als de subquery NULL terug geeft, dan geeft COALESCE een '0' terug in plaats van een NULL.