1

psycopg2 エンジンを使用して、django でアプリを作成します。私の文字列を常に引用したいわけではないようです。テストケースは次のとおりです。

>>> from pypvs.search.models import Addr2zip
>>> kwargs = {
...     'street_name__iexact': 'Common Ground',
...     'state_id__iexact': 'MT',
... }
>>> addrMatch = Addr2zip.objects.extra(
...     where = ['ctystate.zip5 = addr2zip.zip5 AND ctystate.city_name = \'%s\'' % 'Philipsburg'],
...     tables = ['ctystate', 'addr2zip']
... ).filter(**kwargs).order_by('zip5', 'street_name', 'primary_address_low', 'secondary_address_low')
>>> print addrMatch.query
SELECT "addr2zip"."addr2zip_id", "addr2zip"."zip5", "addr2zip"."zip4_low", "addr2zip"."zip4_high", "addr2zip"."street_direction", "addr2zip"."street_name", "addr2zip"."street_suffix", "addr2zip"."street_post_direction", "addr2zip"."primary_address_low", "addr2zip"."primary_address_high", "addr2zip"."primary_address_parity", "addr2zip"."secondary_address", "addr2zip"."secondary_address_low", "addr2zip"."secondary_address_high", "addr2zip"."secondary_address_parity", "addr2zip"."state_id", "addr2zip"."county_code", "addr2zip"."municipality_key", "addr2zip"."urbanization_key", "addr2zip"."record_type" FROM "addr2zip" , "ctystate" WHERE (ctystate.zip5 = addr2zip.zip5 AND ctystate.city_name = Philipsburg AND UPPER("addr2zip"."state_id"::text) = UPPER(MT)  AND UPPER("addr2zip"."street_name"::text) = UPPER(Common Ground) ) ORDER BY "addr2zip"."zip5" ASC, "addr2zip"."street_name" ASC, "addr2zip"."primary_address_low" ASC, "addr2zip"."secondary_address_low" ASC

これらの文字列が引用符で囲まれていない理由は何ですか? たとえば、「共通点」:

AND UPPER("addr2zip"."street_name"::text) = UPPER(Common Ground)

問題が私の実装、psycopg2、または django ORM にあるのかどうかはわかりません。アイデアをいただければ幸いです。

4

3 に答える 3

1

str(query)クエリの近似表現のみを返します。データベースに渡そうとしていますか?

で発行されたクエリはiexact、Django 1.2.3 で正しいようです。上記の結果は になりWHERE UPPER("addr2zip"."street_name"::text) = UPPER(E'Common Ground')ます。どのバージョンを使用していますか?

于 2010-11-26T18:37:58.487 に答える
1

クエリを実行するには、次のようなものを使用します。

from django.db import DEFAULT_DB_ALIAS
queryset.query.get_compiler(DEFAULT_DB_ALIAS).as_sql()
于 2010-12-21T17:29:01.037 に答える
0

しかし、あなたはそれを自分で貼り付けただけです:

where = ['ctystate.zip5 = addr2zip.zip5 AND ctystate.city_name = %s' % 'Philipsburg'],

そのため、構文エラーで構築されたクエリ文字列を取得しました:

AND ctystate.city_name = Philipsburg
于 2010-11-24T22:54:55.850 に答える