"Si un trabajador quiere hacer bien su trabajo, primero debe afilar sus herramientas." - Confucio, "Las Analectas de Confucio. Lu Linggong"
Página delantera > Programación > ¿Cómo realizar una unión interna en Django usando `select_ related`?

¿Cómo realizar una unión interna en Django usando `select_ related`?

Publicado el 2024-11-04
Navegar:709

How to Perform an Inner Join in Django Using `select_related`?

Cómo ejecutar una combinación interna en Django

Para mostrar los datos interconectados de varias tablas en su aplicación Django, puede encontrar la necesidad para realizar una operación de unión interna. Aprovechando el método select_ related, puedes lograr esto sin esfuerzo.

Considera el siguiente escenario: deseas mostrar los nombres de ciudad, estado y país de una publicación en una plantilla HTML. Sin embargo, estos detalles se almacenan en tablas separadas. Para recuperar esta información mediante una combinación interna, puede utilizar el método select_ related de la siguiente manera:

pubs = publication.objects.select_related('country', 'country_state', 'city')

Esta consulta generará una declaración SQL similar a la siguiente:

SELECT "publication"."id", "publication"."title", ..., "country"."country_name", ...  
FROM "publication" 
INNER JOIN "country" ON ( "publication"."country_id" = "country"."id" ) 
INNER JOIN "countrystate" ON ( "publication"."countrystate_id" = "countrystate"."id" ) 
INNER JOIN "city" ON ( "publication"."city_id" = "city"."id" ) 

Los valores recuperados se convertirán automáticamente en instancias del modelo ORM. Esto le permite acceder a los valores de la tabla relacionados a través de sus respectivos objetos dentro de un bucle, como se muestra a continuación:

{% for p in pubs %}
     {{ p.city.city_name}}  # p.city has been populated in the initial query
     # ...
{% endfor %}

Al emplear esta técnica, puede recuperar datos de manera eficiente de varias tablas y presentar información interconectada en sus plantillas HTML, evitando al mismo tiempo accesos adicionales a la base de datos para relaciones directas preseleccionadas.

Último tutorial Más>

Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.

Copyright© 2022 湘ICP备2022001581号-3