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我可以为字段名称添加引号。
还有其他解决办法吗?
创建 JSON 时,向此类字段添加转义双引号。例子:"\"catalogName\""。
如果使用杰克逊:@JsonProperty("\"catalogName\"")
这对我有用。