QueryExecutor
This class executes basic DB-API queries.
The class has 3 methods:
- fetchall - returns list[tuple], i.e. suitable for queries like 'SELECT * FROM table'
- fetchone - returns one entry as a tuple
- execute - executes a query and returns no result suitable for INSERT, UPDATE, DELETE
Example:
queries.py |
---|
| def get_all_music():
return "SELECT * FROM dj_app_music"
def get_music_by_id(id: int):
return "SELECT * FROM dj_app_music", (id,)
|
models.py |
---|
| from django.db import models
# Our demo model
class Music(models.Model):
name = models.CharField(max_length=150)
create_at = models.DateTimeField(auto_now_add=True)
update_at = models.DateTimeField(auto_now=True)
is_delete = models.BooleanField(default=False)
|
views.py |
---|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23 | from django.http import JsonResponse
from django.views import View
from my_app.queries import get_music_by_id
from dj_raw_sql import QueryExecutor
class AllMusicView(View):
def get(self, request, *args, **kwargs):
musics: tuple[tuple] = QueryExecutor.fetchall(get_all_music)
result = []
for music in musics:
result.append({"id": music[0], "name": music[1]})
return JsonResponse({"result":result})
class MusicView(View):
def get(self, request, *args, **kwargs):
music: tuple = QueryExecutor.fetchone(get_music_by_id, id=1)
return JsonResponse({"result": music[1]})
|