java - 如何使用java在Cassandra 3.0中的集合文字内绑定(bind)变量?

标签 java data-binding cassandra-3.0

我有一个 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);
变量 nameid是字符串类型。

我一直在尝试使用准备好的语句用新解析的数据更新我的表;但是在解析数据后,我无法向我的元素列添加更多元素。我收到错误消息:“元素的列表文字无效:集合文字中不支持绑定(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/

相关文章:

cassandra - cassandra中主键上的模式匹配 'like'

cassandra - 提交日志增长的问题

java - java中的zlib解压缩错误

java - 带默认值的 lombok 返回字段的 Spring Rest jackson

javascript - 搜索子串 knockout js

css - 如何在不使用 Dart web-ui 中元素的样式属性的情况下将数据绑定(bind)到 CSS 属性?

Cassandra 与本地读取延迟相比,客户端读取请求延迟较高

java - 在 google disk api 中使用凭据时出现问题

java - 使可变变量可跨许多其他未连接的对象访问

c# - Silverlight 3 - Canvas 上矩形的数据绑定(bind)位置