Ответ 1
Чтобы ответить на ваши вопросы, я немного поработал над этим.
- Кассандра фиксирует микросекунды с типом данных временной отметки?
Микросекунды нет, миллисекунды да. Если я создам вашу таблицу, вставьте строку и попробуйте запросить ее с усеченным временем, она не работает:
[email protected]:stackoverflow> INSERT INTO data (datetime, id, type, data)
VALUES ('2015-02-16T18:00:03.234+00:00','B26354','Blade Runner','Deckard- Filed and monitored.');
[email protected]:stackoverflow> SELECT * FROM data
WHERE id='B26354' AND type='Blade Runner' AND datetime='2015-02-16 12:00:03-0600';
id | type | datetime | data
----+------+----------+------
(0 rows)
Но когда я запрашиваю те же значения id
и type
при задании миллисекунд:
[email protected]:stackoverflow> SELECT * FROM data
WHERE id='B26354' AND type='Blade Runner' AND datetime='2015-02-16 12:00:03.234-0600';
id | type | datetime | data
--------+--------------+--------------------------+-------------------------------
B26354 | Blade Runner | 2015-02-16 12:00:03-0600 | Deckard- Filed and monitored.
(1 rows)
Итак, миллисекунды определенно существуют. Для этой проблемы был создан билет JIRA (CASSANDRA-5870), но он был разрешен как "Не исправить".
- Как я могу видеть, что с помощью cqlsh для проверки?
Один из возможных способов убедиться в том, что миллисекунды действительно существуют, заключается в том, чтобы вставить timestampAsBlob()
внутри blobAsBigint()
, например:
[email protected]:stackoverflow> SELECT id, type, blobAsBigint(timestampAsBlob(datetime)),
data FROM data;
id | type | blobAsBigint(timestampAsBlob(datetime)) | data
--------+--------------+-----------------------------------------+-------------------------------
B26354 | Blade Runner | 1424109603234 | Deckard- Filed and monitored.
(1 rows)
Хотя это и не оптимально, здесь вы можете четко видеть миллисекунду значение "234" на самом конце. Это становится еще более очевидным, если я добавляю строку для той же метки времени, но без миллисекунд:
[email protected]:stackoverflow> INSERT INTO data (id, type, datetime, data)
VALUES ('B25881','Blade Runner','2015-02-16T18:00:03+00:00','Holden- Fine as long as nobody unplugs him.');
[email protected]:stackoverflow> SELECT id, type, blobAsBigint(timestampAsBlob(datetime)),
... data FROM data;
id | type | blobAsBigint(timestampAsBlob(datetime)) | data
--------+--------------+-----------------------------------------+---------------------------------------------
B25881 | Blade Runner | 1424109603000 | Holden- Fine as long as nobody unplugs him.
B26354 | Blade Runner | 1424109603234 | Deckard- Filed and monitored.
(2 rows)