
Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
|
24.06.2014, 16:25
|
|||
|---|---|---|---|
|
|||
Cassandra Optimistic Locking |
|||
|
#18+
Добрый день, Подскажите пожалуйста нужно реализовать следующую логику Optimistic Locking используя Java и Cassandra: Имеется таблица Col1 (PK) Date Versionabc Some Date 3 Для реализации Optimistic locking используется колонка version. Когда мы считываем запись из базы данных - мы запоминаем версию, а когда необходимо сделать update этой записи - проверяем, что версия не поменялась. Нужно сделать так, чтобы обеспечивалась атомарность проверки и обновления записи в таблице. Также необходимо инкрементировать версию при каждом апдейте. Проблемы 1. Version нельзя поместить where для запроса вида Код: sql 1. 2. Version нельзя поместить в PK, т.к. ее нужно изменять (насколько я понял PK - константа и менять его содержимое нельзя) 3. Можно сделать select, получив текущую version, сравнить в Java коде с той версией, которую мы запомнили, и потом сделать update. Здесь проблема в атомарности, точнее в ее отсутствии, а она необходима. Подскажите, как обойти данные проблемы? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
25.06.2014, 19:12
|
|||
|---|---|---|---|
|
|||
Cassandra Optimistic Locking |
|||
|
#18+
Cassandra 2.0, Lightweight transactions http://www.datastax.com/documentation/cassandra/2.0/cassandra/dml/dml_ltwt_transaction_c.html ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
26.06.2014, 14:39
|
|||
|---|---|---|---|
|
|||
Cassandra Optimistic Locking |
|||
|
#18+
Большое спасибо, Запрос, написанный ниже, решает все проблемы: Код: sql 1. Такой запрос возвращает в качестве результата boolean колонку [applied], если изменения были внесены, то результат будет trueб иначе false. Т.о. я могу получить информацию о том, прошел update или нет. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|

start [/forum/topic.php?fid=48&tablet=1&tid=1856887]: |
0ms |
get settings: |
9ms |
get forum list: |
13ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
162ms |
get topic data: |
11ms |
get forum data: |
2ms |
get page messages: |
33ms |
get tp. blocked users: |
2ms |
| others: | 13ms |
| total: | 251ms |

| 0 / 0 |

Извините, этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
... ля, ля, ля ...