gpt4 book ai didi

Cassandra CQL3 切片查询问题 - 如何切片

转载 作者:行者123 更新时间:2023-12-04 23:56:34 25 4
gpt4 key购买 nike

我有一个使用 CQL3 创建的表:

create table compositetest(m_id ascii,i_id int,l_id ascii,body ascii,
PRIMARY KEY(m_id,i_id,l_id));

插入一些随机数据:

cqlsh:testkeyspace1> insert into compositetest(m_id,i_id,l_id,body) VALUES ('m1',1,'l1','b1');
cqlsh:testkeyspace1> insert into compositetest(m_id,i_id,l_id,body) VALUES ('m2',2,'l2','b2');
cqlsh:testkeyspace1> insert into compositetest(m_id,i_id,l_id,body) VALUES ('m1',2,'l2','b2');
cqlsh:testkeyspace1> insert into compositetest(m_id,i_id,l_id,body) VALUES ('m2',1,'l1','b1');
cqlsh:testkeyspace1> insert into compositetest(m_id,i_id,l_id,body) VALUES ('m3',3,'l1','b1');
cqlsh:testkeyspace1> insert into compositetest(m_id,i_id,l_id,body) VALUES ('m3',2,'l2','b2');
cqlsh:testkeyspace1> insert into compositetest(m_id,i_id,l_id,body) VALUES ('m3',1,'l2','b2');
cqlsh:testkeyspace1> select * from compositetest;

m_id | i_id | l_id | body
------+------+------+------
m1 | 1 | l1 | b1
m1 | 2 | l2 | b2
m2 | 1 | l1 | b1
m2 | 2 | l2 | b2
m3 | 1 | l2 | b2
m3 | 2 | l2 | b2
m3 | 3 | l1 | b1

当我进行查询时

cqlsh:testkeyspace1> select * from compositetest where i_id<=3 limit 3;

m_id | i_id | l_id | body
------+------+------+------
m1 | 1 | l1 | b1
m1 | 2 | l2 | b2
m2 | 1 | l1 | b1

现在如果我想获取接下来的 3 行

cqlsh:testkeyspace1> ?

正在尝试为切片范围编写 CQL(不确定是否可以完成)

我的 CQLSh 显示套接字已关闭,我看到了错误

TSocket read 0 bytes

在服务器端我看到以下错误:

ERROR [Thrift:3] 2012-08-12 15:15:24,414 CustomTThreadPoolServer.java (line 204) Error occurred during processing of message.
java.lang.NullPointerException
at org.apache.cassandra.cql3.statements.SelectStatement$Restriction.setBound(SelectStatement.java:1277)
at org.apache.cassandra.cql3.statements.SelectStatement$RawStatement.updateRestriction(SelectStatement.java:1151)
at org.apache.cassandra.cql3.statements.SelectStatement$RawStatement.prepare(SelectStatement.java:1001)
at org.apache.cassandra.cql3.QueryProcessor.getStatement(QueryProcessor.java:215)
at org.apache.cassandra.cql3.QueryProcessor.process(QueryProcessor.java:121)
at org.apache.cassandra.thrift.CassandraServer.execute_cql_query(CassandraServer.java:1237)
at org.apache.cassandra.thrift.Cassandra$Processor$execute_cql_query.getResult(Cassandra.java:3542)
at org.apache.cassandra.thrift.Cassandra$Processor$execute_cql_query.getResult(Cassandra.java:3530)
at org.apache.thrift.ProcessFunction.process(ProcessFunction.java:32)
at org.apache.thrift.TBaseProcessor.process(TBaseProcessor.java:34)
at org.apache.cassandra.thrift.CustomTThreadPoolServer$WorkerProcess.run(CustomTThreadPoolServer.java:186)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
at java.lang.Thread.run(Thread.java:680)

我如何获取接下来的 3 行,关于服务器端的异常,我将提交一个错误。 CQLSh 关闭,我现在必须退出并重新连接

最佳答案

自 CQL2 及更高版本以来,CQL 具有所谓的“自动分页”功能。简而言之,您所描述的内容已由驱动程序处理。

当您的代码请求新行时,服务器仅发送查询的下一行,而不是整个结果。同样,您可以告诉它返回您想要的行数。

在数据库术语中,您执行查询,取回游标。然后你告诉游标获取 N 行,服务器发回(不是整个结果集)。

一旦没有更多的行要返回,游标就结束了。

在 cqlsh 中,当 IIRC 遍历光标到该点时,您会自动显示多达 1k 行。

关于Cassandra CQL3 切片查询问题 - 如何切片,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11925112/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com