我有一个使用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显示Socket已关闭,我看到错误
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已关闭,我现在必须退出并重新连接
答案 0 :(得分:0)
CQL具有自CQL2及更高版本以来所谓的“自动分页”。简而言之,您所描述的内容已由驾驶员处理。
当您的代码请求新行时,服务器只发送查询的下一行,而不是整个结果。类似地,您可以告诉它为您提供所需的行数。
在数据库术语中,您执行查询,获取光标。然后告诉游标获取N个行,服务器发回这些行(而不是整个结果集)。
一旦没有更多行要返回,光标就完成了。
在cqlsh中,当你将光标移动到那一点时,你会自动显示1k行IIRC。