Cassandra Java Driver 将字段名称转换为小写

Bik*_*wal 5 java cassandra-3.0 cassandra-driver

我正在使用 cassandra-driver-core 版本 3.5.1

我在卡桑德拉有一张桌子。表中的所有字段都是驼峰式大小写并用双引号创建。这些字段需要采用驼峰式大小写,因为我的 solr 架构有驼峰式大小写,我们有大约 80-120 字段。

但是当我在这个表中插入我的 json 文档时,使用下面的代码:

//jsonData is json document in String 
Insert insertQuery = QueryBuilder.insertInto(keySpace, table).json(jsonData);
ResultSet resultSet = session.execute(insertQuery.toString());
Run Code Online (Sandbox Code Playgroud)

生成的插入查询:

INSERT INTO asda_search.GROCERIES JSON '{"catalogName":"some data", .....);
Run Code Online (Sandbox Code Playgroud)

cassandra 驱动程序将插入语句中的字段转换为小写,导致以下异常:

Caused by: com.datastax.driver.core.exceptions.InvalidQueryException: JSON values map contains unrecognized column: catalogname
Run Code Online (Sandbox Code Playgroud)

在我的表字段名称是 catalogName

我应该怎么做,以便驱动程序不会小写我的字段?

更新:

我知道我可以创建查询如下:

QueryBuilder.insertInto(keySpace, table).values(fieldNameList, fieldValueList)
Run Code Online (Sandbox Code Playgroud)

在创建时,fieldNameList我可以为字段名称添加引号。

还有其他解决办法吗?

Bik*_*wal 0

创建 JSON 时,向此类字段添加转义双引号。例子:"\"catalogName\""

如果使用杰克逊:@JsonProperty("\"catalogName\"")

这对我有用。