Как добавить USING TTL в запрос с помощью построителя запросов Datastax (драйвер Java 4.17.0)JAVA

Программисты JAVA общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 Как добавить USING TTL в запрос с помощью построителя запросов Datastax (драйвер Java 4.17.0)

Сообщение Anonymous »

Я хочу сгенерировать запрос типа «INSERT INTO table1 (id, data) VALUES (:id, :data) USING TTL :ttl»
с помощью драйвера Datastax Cassandra QueryBuilder.insertInto( ).
Другие связанные вопросы настолько старые и связаны со старым драйвером, что я хотел опубликовать новый.
Я уже что-то пробовал нравится:

Код: Выделить всё

RegularInsert insert = QueryBuilder.insertInto("table1")
.value("id", QueryBuilder.literal("someid"))
.value("data", QueryBuilder.literal("somedata"));

insert.usingTtl(bindMarker("ttl"));

SimpleStatement simple = insert.build().setExecutionProfileName(CassandraClient.SAFE_OPTIONS_PROFILE);

PreparedStatement preparedStatement = context.getCassandraClient().getSession().prepare(simpleStatement);

BoundStatement boundStatement = preparedStatement.bind().setInt("ttl", ttl);

CompletionStage future = context.getCassandraClient().getSession().executeAsync(boundStatement);
Но похоже, что USING не добавлен в запрос, потому что я получаю ошибку:

Код: Выделить всё

java.lang.IllegalArgumentException: ttl is not a variable in this bound statement
Чего мне не хватает или есть ли ошибка в драйвере Datastax Java? Версия драйвера 4.17.0
ОБНОВЛЕНИЕ:
Мой текущий хак заключается в внедрении ИСПОЛЬЗОВАНИЯ TTL с помощью такого кода:

Код: Выделить всё

String cqlQueryWithTtl = insert.asCql() + " USING TTL " + ttl;
Также заметил, что в других частях нашего кода использование Ttl() работает, но не в этом конкретном случае. Странно

Подробнее здесь: https://stackoverflow.com/questions/792 ... ava-driver
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Как добавить USING TTL в запрос с помощью построителя запросов Datastax (драйвер Java 4.17.0)
    Anonymous » » в форуме JAVA
    0 Ответы
    11 Просмотры
    Последнее сообщение Anonymous
  • Как добавить переменную TTL с помощью QueryBuilder в драйвер Java Cassandra 4.17.0
    Anonymous » » в форуме JAVA
    0 Ответы
    9 Просмотры
    Последнее сообщение Anonymous
  • Создание ресурса в блоке using и вне блока using
    Anonymous » » в форуме C#
    0 Ответы
    43 Просмотры
    Последнее сообщение Anonymous
  • Почему вызов функции разрешается в объявление using вместо директивы using в C++? [дубликат]
    Anonymous » » в форуме C++
    0 Ответы
    44 Просмотры
    Последнее сообщение Anonymous
  • Есть ли способ указать «необязательную» глобальную директиву MSBuild using () в C#?
    Anonymous » » в форуме C#
    0 Ответы
    30 Просмотры
    Последнее сообщение Anonymous

Вернуться в «JAVA»