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 при необходимости.