получить ошибку при вызове put_all из тонкого клиента python

Я работаю над примером «create_binary.py», вместо того, чтобы помещать в кеш, я пробовал put_all для нескольких записей для кеша. Пока put проходит успешно, а put_all выдает ошибку.

student_cache = client.get_or_create_cache({
    PROP_NAME: 'SQL_PUBLIC_STUDENT',
    PROP_SQL_SCHEMA: 'PUBLIC',
    PROP_QUERY_ENTITIES: [
        {
            'table_name': 'Student'.upper(),
            'key_field_name': 'SID',
            'key_type_name': 'java.lang.Integer',
            'field_name_aliases': [],
            'query_fields': [
                {
                    'name': 'SID',
                    'type_name': 'java.lang.Integer',
                    'is_key_field': True,
                    'is_notnull_constraint_field': True,
                },
                {
                    'name': 'NAME',
                    'type_name': 'java.lang.String',
                },
                {
                    'name': 'LOGIN',
                    'type_name': 'java.lang.String',
                },
                {
                    'name': 'AGE',
                    'type_name': 'java.lang.Integer',
                },
                {
                    'name': 'GPA',
                    'type_name': 'java.math.Double',
                },
            ],
            'query_indexes': [],
            'value_type_name': 'SQL_PUBLIC_STUDENT_TYPE',
            'value_field_name': None,
        },
    ],
})

положить работает нормально

student_cache.put(
1,
Student(LOGIN='jdoe', NAME='John Doe', AGE=17, GPA=4.25),
key_hint=IntObject
)

put_all не работает

student_cache.put_all({1: Student(LOGIN='jdoe', NAME='John Doe', AGE=17, GPA=4.25), 2: Student(LOGIN='jdoe2', NAME='John Doe2', AGE=18, GPA=4.25)})

put_all выдает ошибку:

Трассировка (последний последний вызов): файл «C:/ignite/pyignite/examples/create_binary.py», строка 105, в student_cache.put_all({1: Student(LOGIN='jdoe', NAME='John Doe', ВОЗРАСТ = 17, средний балл = 4,25), 2: студент (ВХОД = 'jdoe2', NAME = 'John Doe2', ВОЗРАСТ = 18, средний балл = 4,25)}) Файл "C:\Users\nbkmqoi\AppData\Roaming\Python \Python35\site-packages\pyignite\utils.py", строка 169, в ste_wrapper поднять exc(result.message) pyignite.exceptions.CacheError: не удалось обновить ключи (повторите попытку обновления, если возможно).: [1, 2]

Как заставить работать put_all? Спасибо!


person Top Market    schedule 11.12.2019    source источник
comment
Кажется, для установки нам нужно указать key_hint (key_hint=IntObject). Но как поставить key_hint для put_all?   -  person Top Market    schedule 11.12.2019


Ответы (1)


Я понял. Нужно добавить тип данных в turple с ключом

student_cache.put_all({(1, IntObject): Student(LOGIN='jdoe', NAME='John Doe', AGE=17, GPA=4.25), (2, IntObject) : Student(LOGIN='jdoe2', NAME='John Doe2', AGE=18, GPA=4.25)})

person Top Market    schedule 11.12.2019