- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
使用 YCQL,我需要向查询添加什么才能返回结果所在的特定平板电脑?
[免责声明]:这个问题最初是在 YugabyteDB 社区 Slack channel 上提出的。
最佳答案
要确定一行所在的分区,您可以将分区列(在主键中)提供给 partition_hash函数并取回哈希码。
ycqlsh:k> create table t(k text primary key, v text);
ycqlsh:k> insert into t(k, v) values ('a', '1');
ycqlsh:k> insert into t(k, v) values ('b', '2');
ycqlsh:k> insert into t(k, v) values ('c', '3');
ycqlsh:k> select partition_hash(k), k, v from t;
partition_hash(k) | k | v
-------------------+---+---
27916 | c | 3
44389 | a | 1
60372 | b | 2
这必须与
system.partitions
中的信息相匹配。表以确定特定哈希码将落在哪个分区/平板电脑中。 [请参阅进一步的示例查询。] 这是另一个具有多列主键的示例,其中只有
user_id
column 是分区列。
ycqlsh:k> CREATE TABLE IF NOT EXISTS msgs(
user_id text,
msg_id integer,
msg text,
PRIMARY KEY((user_id), msg_id)
);
ycqlsh:k> insert into msgs(user_id, msg_id, msg) VALUES ('A', 1, 'foo');
ycqlsh:k> insert into msgs(user_id, msg_id, msg) VALUES ('A', 2, 'bar');
ycqlsh:k> insert into msgs(user_id, msg_id, msg) VALUES ('A', 3, 'jar');
ycqlsh:k> insert into msgs(user_id, msg_id, msg) VALUES ('B', 1, 'foo');
ycqlsh:k> insert into msgs(user_id, msg_id, msg) VALUES ('B', 2, 'bar');
ycqlsh:k> insert into msgs(user_id, msg_id, msg) VALUES ('B', 3, 'jar');
ycqlsh:k> select partition_hash(user_id), user_id, msg_id, msg from msgs;
partition_hash(user_id) | user_id | msg_id | msg
-------------------------+---------+--------+-----
44013 | A | 1 | foo
44013 | A | 2 | bar
44013 | A | 3 | jar
52014 | B | 1 | foo
52014 | B | 2 | bar
52014 | B | 3 | jar
(6 rows)
partition_hash
返回的值在 [0..64K) 空间中,并将这些映射回平板电脑,
system.partitions
可以查询表。例如,
ycqlsh:k> select * from system.partitions where keyspace_name = 'k';
keyspace_name | table_name | start_key | end_key | id | replica_addresses
---------------+------------+-----------+---------+--------------------------------------+-------------------------
k | msgs | 0x | 0x7fff | 58097f2e-967f-d785-3a42-f647b498ef08 | {'127.0.0.1': 'LEADER'}
k | msgs | 0x7fff | 0x | f7f2a64e-5bf2-fbba-554f-d26008c02bcc | {'127.0.0.1': 'LEADER'}
k | t | 0x | 0x7fff | 15363091-6577-9aa6-584c-64304cec7f6e | {'127.0.0.1': 'LEADER'}
k | t | 0x7fff | 0x | 0d4e2bcc-ac97-bd9e-8148-7bedb7c4bd86 | {'127.0.0.1': 'LEADER'}
当您使用
partition_hash
时, 查询后
system.partitions
,您只需要找到
partition_hash
的位置value 落在
system.partitions
中开始和结束键的范围内回复。请记住,start_key 是包含的,end_key 是不包含的。
关于yugabyte-db - 如何使用 YCQL 查询返回特定平板电脑,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67335032/
我正在尝试从 Linux 远程登录到 Windows PC,但显示错误“登录失败”。 这是我的 Python 脚本。我正在使用 pexpect 模块。我也尝试过使用 telnetlib 但同样的错误:
大多人在windows平台用的tomcat都是免安装版本的,很自然想到复制几份目录,就是在同一个电脑上跑多个tomcat服务了。实际上是不可以的。经过如下方法就可以实现统一台服务器(电脑)上运行多个
正负号是一个不常用的符号,很多小伙伴不知道怎么打出来,打出来确实有点麻烦,很多小伙伴不知道怎么弄,今天小编就给大家带来了轻松便捷的方法吧。 正负号怎么打出来 方法1、“&plu
在一项作业中,我被要求创建一个 [7] x [7] 矩阵,以及一个与计算机对战的井字棋游戏。玩家是 X,计算机是 O。[1][1] 是选择 1,[1][3] 是选择 2,[1][5] 是选择 3,[3
我想知道如何开发应用程序/服务器。我的安卓手机会在我说话时录制我的声音,并将其发送到 PC,然后使用 PC 的扬声器播放。 我想我需要一个在计算机上运行的媒体服务器来接收我的声音,然后使用手机上已有的
我正在开发一个使用蓝牙玩的安卓游戏应用程序。在搜索蓝牙设备时,结果包含移动设备和 mac pc/笔记本电脑。我只想在结果列表中列出移动设备。是否可以确定检测到的设备是否为移动设备? 最佳答案 当你有
在学习 Meteor 框架的过程中,我正在将 Yik Yak 移动应用程序重新创建为 Web 应用程序。但该应用程序是完全匿名的,没有用户帐户,但您仍然只能对帖子投赞成票或反对票一次。如何做到这一点?
我花了一些时间寻找解决方案。我已经使用 MacPorts 在我的 mac 上重新安装了 Vim 好几次。 vim --version 命令显示 +clipboard 和 +xterm_clipboar
我是一名优秀的程序员,十分优秀!