In this code I am filtering objects by distance, so distance is a method from geopy that accepts two tuple with lat1, long2 and long1, long2. However my second tuple got F()
Are you sure it’s the tuple that is incorrect? What is query_distance?
Is the distance function a database function? (Does it translate to SQL, or is it a python-based function?) If it’s a python function, then it can’t be used in the annotation clause.
The ORM works by creating an SQL statement that gets shipped off to the database, where it is parsed and executed.
The entire statement must rely upon functions available to the database engine. You can’t mix functions between what’s in the database and what only exists in your application.
What you would need to look for would be the equivalent PostGIS function to perform that calculation, or, create your own User-Defined Function to implement it.
Different issue, and not relevant here. Your root issue is that you’re trying to use a Python function in an sql statement. The “float” error is a symptom of the deeper problem. You’re trying to pass an F function to a python function that has no idea of what to do with it.
is going to be evaluated before it is constructed into an SQL statement and sent to the database. There is no field address__latitude to retrieve at this point in time, because the processing is still occurring in your application.
Logically, it’s no different than the expression:
Where query_distance (the right-hand side of the assignment operation) is evaluated before the query is sent to the database.