Как использовать «range_key_condition» для запроса таблицы DynamoDB с помощью boto? - PullRequest
5 голосов
/ 06 марта 2012

Чтобы получить range_key между (0,9999), могу ли я сделать это так?

conn = boto.connect_dynamodb()
table = conn.get_table("mytable")
...
result = table.query(
      hash_key = "66", 
      range_key_condition = {"0":"GE", "9999":"LE"}
      )

с boto v2.2.2-dev, я всегда получаю пустые результаты

РЕДАКТИРОВАТЬ: Это еще один пример ошибки:

In [218]: qa = taa.query(hash_key = "1")

In [219]: qa.next()
Out[219]: {u'attra': u'this is attra', u'key': u'1', u'range': 1.1}

Все в порядке без "range_key_condition" выше

In [220]: qa = taa.query(hash_key = "1", range_key_condition = {0.1: "GE"})

In [221]: qa.next()
---------------------------------------------------------------------------
AttributeError                            Traceback (most recent call last)
/home/user/python/enva/<ipython-input-221-dba0a498b6e1> in <module>()
----> 1 qa.next()

/home/user/python/enva/local/lib/python2.7/site-packages/boto-2.2.2_dev-py2.7.egg/boto/dynamodb/layer2.pyc
in query(self, table, hash_key, range_key_condition,
attributes_to_get, request_limit, max_results, consistent_read,
scan_index_forward, exclusive_start_key, item_class)
    559         """
    560         if range_key_condition:
--> 561             rkc = self.dynamize_range_key_condition(range_key_condition)
    562         else:
    563             rkc = None

/home/user/python/enva/local/lib/python2.7/site-packages/boto-2.2.2_dev-py2.7.egg/boto/dynamodb/layer2.pyc
in dynamize_range_key_condition(self, range_key_condition)
    83         structure required by Layer1.
    84         """
---> 85         return range_key_condition.to_dict()
   86
   87     def dynamize_scan_filter(self, scan_filter):

AttributeError: 'dict' object has no attribute 'to_dict'

Ответы [ 2 ]

5 голосов
/ 06 марта 2012

Если вы используете последнюю версию boto (и похоже, что вы), то условия были изменены по сравнению с предыдущими версиями, чтобы сделать запрос более читабельным.Попробуйте это:

from boto.dynamodb.condition import *
conn = boto.connect_dynamodb()
table = conn.get_table("mytable")
...
result = table.query(
  hash_key = "66", 
  range_key_condition = BETWEEN(0, 9999))

Это должно работать, хотя вам придется обновить свой бот-код, так как я только что обнаружил ошибку в МЕЖДУ во время исследования этого вопроса (см. https://github.com/boto/boto/issues/620).

1 голос
/ 06 марта 2012

Из API , не ясно, что вам разрешено включать более одного условия. Работает ли это, если вы просто выполняете одно из условий? Кроме того, есть оператор BETWEEN, который может работать для вас: range_key_condition = {(0,10000):"BETWEEN"}, но он может не работать, если ваши значения действительно являются строками, а не числами. Я не использовал этот API, поэтому я, вероятно, спрашиваю в списке рассылки boto или IRC .

Обновление: основываясь на только что добавленном сообщении об ошибке и просмотре кода Boto на github, я думаю , что это ошибка в Boto. Table.query просто звонит Layer2.query. Layer2.query ожидает, что range_key_condition будет объектом Condition (у которого есть метод to_dict), но вы предоставляете обычный dict (который, очевидно, не имеет метода to_dict). Table.query должен преобразовывать ваш диктант в объект Condition и предоставлять его Layer2.query, но это не так. Я бы пошел в список рассылки или IRC за помощью.

...