服务器端警告:聚合查询在没有分区键的情况下使用
Server-side warning: Aggregation query used without partition key
在使用Cassandra的C/C++驱动程序时,我有时会在控制台中弹出以下消息:
1460937092.140 [WARN] (src/response.cpp:51:char*
cass::Response::decode_warnings(char*, size_t)):
Server-side warning: Aggregation query used without partition key
想知道是否有人知道这意味着什么。我应该在代码中寻找可能产生此错误的内容,或者它只是服务器端我无法控制的内容?
该警告告诉您,您正在使用不带分区键的用户定义聚合进行选择。这可能是一个内置的,比如avg、count、min、max,也可能是你自己的。
一个例子:
select avg(temperature) from weather_data;
与
select avg(temperature) from weather_data where id = 1;
第一个示例将扫描集群中的所有数据行,这可能会严重影响性能。如果有足够的行,查询可能会超时。
第二种方法只扫描一个数据分区,将查询保留在一台服务器上,这是推荐的用法。
相关文章:
- 在没有太多条件句的情况下,我如何避免被零除
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 在未初始化映射的情况下,将值插入到映射的映射中
- 是默认情况下分配给char数组常量的值
- 为什么我不能在不创建字符串变量的情况下使用函数的字符串输出
- 如何在不产生任何垃圾的情况下获得C中的像素
- 在已经使用Git的情况下减少编译时间
- 为什么在Windows上的VS 2019和Clang 9中"size_t"在没有标题的情况下工作
- 如何在没有信号的情况下从C++执行QML插槽
- 如何在不知道向量大小的情况下输入向量内部的向量?
- 为什么在某些情况下不写入此文件?
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 在没有Xcode的情况下在Mac捆绑包中嵌入框架
- UE4-如何在给定4个屏幕坐标的情况下缩放纹理或材质
- 为什么需要复制构造函数,在哪些情况下它们非常有用
- 在C++中如何在没有pow的情况下进行基础计算
- 松弛原子与无同步情况下的记忆连贯性
- 在 Windows 上,是否可以让 dll 在不使用 PATH 环境变量的情况下在另一个文件夹中查找依赖项?
- 服务器端警告:聚合查询在没有分区键的情况下使用
- 如何在没有 Windows 分配驱动器号的情况下创建分区