4

我仅在不存在时才使用以下 CQL 语法创建键空间:

CREATE KEYSPACE IF NOT EXISTS Test WITH replication 
                = {'class':'SimpleStrategy', 'replication_factor':1};

但它给出了错误:

Exception in thread "main" com.datastax.driver.core.exceptions.SyntaxError: line 1:23 extraneous input 'EXISTS' expecting '='
at com.datastax.driver.core.exceptions.SyntaxError.copy(SyntaxError.java:35)
at com.datastax.driver.core.DefaultResultSetFuture.extractCauseFromExecutionException(DefaultResultSetFuture.java:256)
at com.datastax.driver.core.DefaultResultSetFuture.getUninterruptibly(DefaultResultSetFuture.java:172)
at com.datastax.driver.core.SessionManager.execute(SessionManager.java:91)
at com.datastax.driver.core.SessionManager.execute(SessionManager.java:83)

请帮我解决这个问题?语法有什么问题?

4

2 回答 2

2

这似乎是正确的语法(参考:docs)。我刚刚在 Cassandra 2.0.7 上亲自尝试过。

“如果不存在”选项是 CQL3 的一部分,它首先随 Cassandra 1.2 提供。我会仔细检查你的 Cassandra 版本,看看这个选项是否可用。

于 2014-05-07T23:36:42.930 回答
1

如果您遇到同样的 SyntaxError(并且您使用 Eclipse),请首先确保您的 Eclipse IDE 不使用 Cp1252 字符编码而是 UTF-8(或与 Cassandra 环匹配的任何其他编码(通常是 UTF-8)导出

于 2015-05-21T11:32:35.137 回答