我有一个 java 应用程序,我正在其中解析数据并将其更新到我的 Cassandra 3.0 数据库。到目前为止,我一直成功,直到涉及到我的用户定义类型的列。
我的尝试:
String statement_update = "UPDATE table SET "
+ "elements = elements + [{name: ? , associations: []}]"
+ " WHERE id = ?
元素是我的 Cassandra 3.0 数据库中的用户定义类型。
它由名称(数据类型:文本)和关联(数据类型:列表)组成。
PreparedStatement prepared_update = session.prepare(statement_update);
bound_update = prepared_update.bind(name, id);
变量
name
和 id
是字符串类型。我一直在尝试使用准备好的语句用新解析的数据更新我的表;但是在解析数据后,我无法向我的元素列添加更多元素。我收到错误消息:“元素的列表文字无效:集合文字中不支持绑定(bind)变量。”我该如何解决或解决这个问题?
我已经尝试过将 statement_update 更改为
“UPDATE table SET elements = elements + ? WHERE id = ?”
的方法,但我不知道要添加到我的绑定(bind)语句中的列表(或者即使是列表)。满足我的用户定义类型需要什么:元素?
最佳答案
尝试另一种更新表示法:
session := getGocqlSession()
err := session.Query(
"UPDATE table SET mymapcolumn[?] = ? WHERE rowkey = ?",
mapKey, mapValue, rowKey,
).Exec()
这对我有用。我在 Go 上做过这个,但也许这种方法会有所帮助。
关于java - 如何使用java在Cassandra 3.0中的集合文字内绑定(bind)变量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45865891/