marzo 15, 2018

Inner join y otras uniones de tablas en CodeIgniter

Introducción

En estos días tuve la inquietud de cómo hacer un inner join con 2 o más tablas utilizando el query builder de CodeIgniter. Y como ya he encontrado la solución, decidí reunir todas mis investigaciones para explicarlo. Vamos allá.

Hacer inner join de 2 tablas

Aquí dejo la solución. Sólo cambia el nombre de tus tablas y las condiciones como se deba. En este caso se unen 2 tablas.

 Inner join de 3 tablas

Ahora veamos cómo hacer un inner join de 3 tablas. Ya con este ejemplo podemos imaginar cómo podemos unir infinitas tablas.

Left, right, outer

No siempre vamos a querer un inner join, que es la opción por defecto. Podemos pasar un tercer argumento al llamar a join. Por ejemplo, para left es así:

Eso fue para left, pero el tercer argumento puede ser cualquiera de la lista de abajo.

Lista de opciones para unir tablas

  • left
  • right
  • outer
  • inner
  • left outer
  • right outer

Ejemplo

Para implementar esto en un modelo de CodeIgniter, podríamos hacerlo así:

Referencias

Si quieres saber más sobre el tema, aquí dejo el link de la documentación oficial:

Query Builder Class | CodeIgniter V3

Conclusión y notas

Es muy fácil hacer uniones de tablas de cualquier tipo utilizando este framework. Recuerda que el código de ejemplo, al menos como yo lo recomiendo, va dentro de un modelo. Y no olvides cargar la base de datos en dicho modelo con load->database() en el constructor.

 

Python: Volumen y área total de una caja

Introducción

Esto es otro ejercicio sacado de codewars. Se trata de calcular el volumen y el área total de una caja, y devolverlos en una lista. El problema dice más o menos así:

Dada la altura, anchura y profundidad de una caja, calcular su volumen y su superficie o área total.

Es decir, tenemos que devolver el volumen, y la suma de la superficie de cada cara. Recordemos que es una caja, no un cubo.

Imagen explicativa

Al principio me confundí y pensé que era un cubo, pero es una caja. Una caja como las que tenemos en casa, esas en donde guardamos cosas. Es así:

Créditos al respectivo autor de la imagen, aunque cuando me la robé, puse “Etiquetadas para reutilización” en la búsqueda, pero no hay que confiarse.

Nota: Width es profundidad, Length anchura y Height altura. Tal vez no lo sea así para los matemáticos, pero para este ejercicio sí.

Calcular volumen y área total

Ahora sí vamos a la función.

Calcular volumen

Para esto, simplemente multiplicamos anchura por altura por profundidad. No importa el orden ni las medidas, porque siempre dará el mismo resultado.

Calcular área

Para esto, sólo se me ocurrió multiplicar primero la anchura por la profundidad, y con eso obtenía la superficie de la cara de arriba. Eso lo multiplicaba por 2, pues la cara de abajo y arriba miden lo mismo.

Luego, al resultado anterior le sumé el resultado de multiplicar la altura por la profundidad; con eso obtenía la superficie de una cara lateral. Y a eso lo multiplicaba por 2, pues del otro lado la cara era igual.

Y finalmente, sumaba a los resultados anteriores el resultado de multiplicar la anchura por la altura por 2. Ya que con anchura y altura obtenemos la superficie de la cara de adelante.

Solución al ejercicio

Una vez explicado eso, el ejercicio queda así:

Y pasa correctamente las pruebas: