1

我创建了一个包含两个列字段的键空间。一个是 ID,另一个是名称。我已在该键空间中插入记录。我想更新特定 id 的名称字段。

我使用了以下 CQL 查询

UPDATE keyspaceName/columnFalmilyName SET name='name' WHERE id = 'id' 

在执行此查询时,它会抛出异常

InvalidRequestException(why:line 1:56 mismatched input 'id' expecting K_KEY)...

如果查询框架错误,如何使用 CQL 更新记录?

4

2 回答 2

0

插入和更新需要指定行键,而您似乎正在尝试使用列名。插入新的 id、name 对时使用了什么键?

请参阅 [http://cassandra.apache.org/doc/cql3/CQL.html][1] 上的 CQL 文档

<update-stmt> ::= UPDATE <tablename>
                  ( USING <option> ( AND <option> )* )?
                  SET <assignment> ( ',' <assignment> )*
                  WHERE <where-clause>
The UPDATE statement writes one or more columns for a given row in a table. The 
<where-clause> is used to select the row to update and must include all columns 
composing the PRIMARY KEY. Other columns values are specified through <assignment> 
after the SET keyword.

您需要查看您的 ColumnFamily 定义并查看您的主键是什么。

于 2013-01-18T23:09:23.470 回答
0

你试过吗:UPDATE keyspaceName/columnFalmilyName SET name='name' WHERE id = (without '')

于 2020-06-03T15:03:34.770 回答