Nota: mira la diferencia entre coalesce y la función ifnull.
El operador de coalescencia (que de hecho no es un operador sino una función) toma una lista variable de argumentos y devuelve el primero que encuentre que no sea nulo.
Explicado con palabras sencillas, llamamos a COALESCE con una lista de argumentos.
Si, por ejemplo, la lista es esta:
COALESCE(NULL, 0, "Hola")
Devolverá 0
Si la lista es:
COALESCE(NULL, NULL, "Hola")
Devolverá “Hola”
Evalúa cada elemento de izquierda a derecha. Si el primero es nulo, pasa al segundo. Si el segundo lo es, pasa al tercero, y así hasta terminar con la lista.
Esto sirve cuando puede que un resultado devuelva NULL, y queremos que en lugar de eso devuelva otro valor. Un ejemplo podría ser el promedio de una consulta, que devuelve null en lugar de cero cuando no hay datos.
Para entender mejor esta función, veamos esta tabla de mascotas que tengo. Vemos que la edad es un número entero.
Ahora, si yo quisiera sacar la suma de edades podría hacer la siguiente consulta:
SELECT SUM(edad) FROM mascotas;
Todo sale de maravilla, la suma es 40.
Pero bueno, eso fue porque yo ya tengo datos en la tabla. ¿Qué pasa si ponemos un sistema para un cliente y no hay datos? bueno, veamos.
Voy a borrar los datos de la tabla con la siguiente consulta:
TRUNCATE mascotas;
Al consultar, no hay nada:
Uno esperaría que al ejecutar la siguiente consulta…
SELECT SUM(edad) FROM mascotas;
El resultado sea 0.
Pero al hacerla sobre la tabla vacía, devuelve NULL, como se ve a continuación:
Ahora, en lugar de hacer la misma consulta para sumar, haré esto:
SELECT COALESCE(SUM(edad), 0) FROM mascotas;
Como en este caso SUM devolverá NULL, COALESCE tomará el siguiente elemento de la lista. ¿y cuál es? el 0.
Si la ejecuto sin datos, sale 0, como se muestra en la imagen:
Ingresaré algunos datos y si luego la vuelvo a ejecutar, sale la suma:
Por lo que COALESCE no afecta a nuestras consultas, sino que nos ayuda a manejar errores nulos. Podemos combinarla con cualquier otra función que devuelva NULL en caso de que no encuentre datos, como AVG.
El día de hoy te mostraré cómo crear un servidor HTTP (servidor web) en Android…
En este post te voy a enseñar a designar una carpeta para imprimir todos los…
En este artículo te voy a enseñar la guía para imprimir en una impresora térmica…
Hoy te voy a mostrar un ejemplo de programación para agregar un módulo de tasa…
Los usuarios del plugin para impresoras térmicas pueden contratar licencias, y en ocasiones me han…
Hoy voy a enseñarte cómo imprimir el € en una impresora térmica. Vamos a ver…
Esta web usa cookies.
Ver comentarios