Niestety nie ma funkcji dla twojego zachowania, ale łatwo jest stworzyć własną funkcję, jeśli masz do tego uprawnienia, w przeciwnym razie możesz również dodać IF THEN ELSE
na twoje zapytanie, jak już pokazałeś, ale to nie byłaby odpowiedź na twoje pytanie. Jeśli chcesz utworzyć funkcję, będziesz miał problem, że potrzebujesz wyraźnych typów parametrów, a mysql niestety nie działa również przeciążanie funkcji (ta sama nazwa funkcji, ale różne typy parametrów). Potrzebujesz więc dla różnych typów różnych funkcji z różnymi nazwami funkcji. Wyglądałoby to tak:
CREATE FUNCTION `fmap_varchar`(e1 VARCHAR(255), e2 VARCHAR(255) )
RETURNS VARCHAR(255) DETERMINISTIC
RETURN IF(e1 IS NULL, NULL, e2);
Być może będziesz musiał również zadbać o poprawny zestaw znaków, który możesz również określić w klauzuli return.
A rozwiązanie z zapytaniem, które już podałeś:
SELECT IF(something IS NULL, NULL, anotherthing) FROM your_table;