を作ります(aからbへ)と一致する接続を取得する必要があります。アイブ氏は、これらの2 possibilitesを使用しますが、両方の長い旅のために10秒以上にすることができ、同時に必要があります。私は、次のszenario上のパフォーマンスの問題を持っている外部キーの高速クエリ、ジャンゴ
for i in range(0, len(journey)-1):
try:
connection = Connection.objects.get(station1_id=journey[i], station2_id=journey[i+1])
except Connection.DoesNotExist:
try:
connection = Connection.objects.get(station1_id=journey[i+1], station2_id=journey[i])
except Connection.DoesNotExist:
pass
journey.connections.add(connection)
for i in range(0, len(journey)-1):
s1 = Station.objects.get(id = journey[i])
s2 = Station.objects.get(id= journey[i+1])
if (Connection.objects.filter(station1=s1, station2=s2).exists()):
connection = Connection.objects.get(station1=s1, station2=s2)
elif (Connection.objects.filter(station1=s2, station2=s1).exists()):
connection = Connection.objects.get(station1=s2, station2=s1)
journey.connections.add(connection)
がどのように私はそれを速くすることができますか?
ありがとうございますが、残念ながらそれはパフォーマンスを変更しませんでした – DarkShark