Using PostgreSQL 8.3 and fulltext indexing, before QS-RF I was able to execute queries like:
----- q = 'hello world' queryset = Entry.objects.extra( select={ 'snippet': "ts_headline(body, query)", 'rank': "ts_rank_cd(body_tsv, query, 32)", }, tables=["plainto_tsquery(%s) as query"], where=["body_tsv @@ query"], params=[q] ) ----- After updating to include QS-RF, it seems that the 'tables' parameter to the extra() method is copied without parameter substitution straight into the SQL 'FROM' clause, and with the entire thing quoted. So that before I was getting something like SELECT FROM plainto_tsquery('hello world') as query, blog_entry, .... but now, it's ending up as something like: SELECT FROM "plainto_tsquery(%s) as query", blog_entry, .... any thoughts on the best way to do this now with QS-RF? In the meantime as a workaround, I'm just repeating the call to the PostgreSQL plainto_tsquery() function 3 times, as in: ----- q = 'hello world' queryset = Entry.objects.extra( select={ 'snippet': "ts_headline(body, plainto_tsquery(%s))", 'rank': "ts_rank_cd(body_tsv, plainto_tsquery(%s), 32)", }, where=["body_tsv @@ query"], params=[q], select_params=[q, q] ) ----- which I have to think isn't quite as efficient (if it is, that'd be good to know). Barry --~--~---------~--~----~------------~-------~--~----~ You received this message because you are subscribed to the Google Groups "Django users" group. To post to this group, send email to django-users@googlegroups.com To unsubscribe from this group, send email to [EMAIL PROTECTED] For more options, visit this group at http://groups.google.com/group/django-users?hl=en -~----------~----~----~----~------~----~------~--~---