У меня есть требование, в котором я должен выполнить операцию удаления в cassandra, используя только ключ разделения (удалить все записи с ключом раздела) в пакетной операции с использованием spring и springboot, но метод удаления CassandraBatchOperations принимает только введите полный объект сущности, например
CassandraBatchOperations delete(Object... entities);
, у меня есть таблица, например, table1, и у нее есть ключи: key1- partiton key, key2 -clustering key1, key 3-clustering key2
so my requirement is that in batch operation below query should run
DELETE from table1 where key1='input key';
so when i create an object like
tableEntity recordToDelete=new Table1Entity();
recordToDelete.setKey1('input key');
and run batchOperations like
CassandraBatchOperations batchOps=cassandraTemplate.batchOps();
batchOps.delete(recordToDelete);
then the effective query getting generated is
DELETE from table1 where key1='input key' and key2=null and key3=null
затем Я получаю исключение ниже
> rg.springframework.data.cassandra.CassandraInvalidQueryException:
> Query; CQL [BEGIN BATCH DELETE FROM table1 WHERE key2=null AND
> key3=null AND key1='0002';APPLY BATCH;]; Invalid null value in
> condition for column key2; nested exception is
> com.datastax.driver.core.exceptions.InvalidQueryException: Invalid
> null value in condition for column key2
Проблема в том, что при создании запроса также учитываются ключи кластеризации key2 и key3, которые не имеют значений, поскольку я хочу удалить только по ключу раздела.
Я хочу знать, как я могу удалить только с помощью ключа разделения, получение списка записей из БД не является вариантом, так как я также вставляю записи в кассандру в рамках той же пакетной операции, и может случиться так, что также будет добавлена запись в той же пакетной операции, которая имеет ключ раздела, который я хочу удалить ete. поэтому в этом случае, если я получу и удалю запись, новая запись, вставляемая в пакетной операции, не будет удалена.