DjangoORMを使用してデータベースクエリを処理しています。私は次のdbテーブルを持っています:
- 資源
- resource_pool
- resource_pool_elem
- 予約
および次のモデル:
class Resource(models.Model):
name = models.CharField(max_length=200)
class Reservation(models.Model):
pass
class ResourcePool(models.Model):
reservation = models.ForeignKey(Reservation, related_name="pools", db_column="reservation")
resources = models.ManyToManyField(Resource, through="ResourcePoolElem")
mode = models.IntegerField()
class ResourcePoolElem(models.Model):
resPool = models.ForeignKey(ResourcePool)
resource = models.ForeignKey(Resource)
現在、一連の予約で使用されているリソースを照会する必要があります。次のクエリを使用します。
resourcesNames = []
reservations = []
resources = models.Resource.objects.filter(
name__in=resourcesNames, resPool__reservation__in=reservations).all()
これは、これに似たSQLクエリに一致すると思います。
select *
from resource r join resource_pool rp join resource_pool_elem rpe join reservation reserv
where r.id = rpe.resource and
rpe.pool = rp.id and
reserv.id = rp.reservation and
r.name in (resourcesNames[0], ..., resourcesNames[n-1])
reserv.id in (reservations[0], ..., reservations[n-1])
ここで、このクエリに制限を追加します。各プールには、排他モードのブールフラグがあります。各プールの要求された排他的フラグを含む追加の入力リストがあり、exclusive = trueの場合、排他的フラグが要求された排他的フラグと一致するプールのリソース、または排他的フラグがfalseのプールのリソースのみを照会したいと思います。次のようなコードでPythonを使用してSQLクエリを作成できます。
query = "select *
from resource r join resource_pool rp join resource_pool_elem rep
join reservation reserv
where r.id = rpe.resource and
rpe.pool = rp.id and
reserv.id = rp.reservation and
reserv.id in (reservations[0], ..., reservations[n-1]) and ("
for i in resourcesNames[0:len(resourcesNames)]
if i > 0:
query += " or "
query += "r.name = " + resourcesNames[i]
if (exclusive[i])
query += " and p.mode == 0"
query += ")"
このSQLクエリをDjangoクエリで表現する方法はありますか?