Sobes.tech
Back to questions
Junior — Middle
59

Применяли ли вы метод execute из Django для выполнения необработанных SQL-запросов?

Companies where asked
Стилсофт

Answer from AI

sobes.tech AI

Да, в Django можно использовать метод execute объекта курсора для выполнения необработанных (raw) SQL-запросов. Это полезно, когда ORM не поддерживает нужную операцию или для оптимизации.

Пример использования:

from django.db import connection

with connection.cursor() as cursor:
    cursor.execute("SELECT * FROM myapp_mymodel WHERE id = %s", [1])
    row = cursor.fetchone()
    print(row)

Важно использовать параметризацию запросов (второй аргумент execute), чтобы избежать SQL-инъекций.

Также Django предоставляет метод raw() для моделей, который позволяет выполнять необработанные SELECT-запросы и получать объекты модели:

MyModel.objects.raw('SELECT * FROM myapp_mymodel WHERE id = %s', [1])

Таким образом, метод execute — это низкоуровневый способ выполнять любые SQL-запросы в Django при необходимости.