- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
那么,让我们看看我能否简要解释一下我的问题。
假设我们有一个 HBase 表,其中包含每次访问迪斯科舞厅的信息:每个迪斯科舞厅都会记录其姓名、访问者的姓名以及访问者的日期。 (是的,这是一个愚蠢的例子,我知道..)。
因此,例如,这些将是表的一些值:
..
ministryOfSoundJamesOliver01022017
ministryOfSoundJamesOliver02022017
ministryOfSoundJamesOliver03022017
ministryOfSoundOliviaNewton04042017
ministryOfSoundOliviaNewton06042017
...
pachaibizaJohnMcKiness06042017
pachaibizaJohnMcKiness04042017
pachaibizaWilliamForrester04042017
..
RowKey 具有以下结构:
discoName
personName
dayOfTheYear
(该表还有其他一些列/限定符,但对于这个问题我不介意它们)。
问题是:想象一个男孩只是喜欢去 Ministry Of Sound。他只是喜欢它,他把所有的钱都花在了迪斯科和毒品上(但这不是这里的重点)。
我的目标是输出每个参加 Ministry Of Sound 的人。在我的扫描中,这个家伙一直出现在结果中,所以我必须丢弃很多条目来寻找下一个访客。 F.E:
..
ministryOfSoundJohnnyYonkie01022017
ministryOfSoundJohnnyYonkie02022017
ministryOfSoundJohnnyYonkie03022017
ministryOfSoundJohnnyYonkie04022017
ministryOfSoundJohnnyYonkie05022017
ministryOfSoundAnotherDude02022017
...
为了注册 AnotherDude,我必须放弃 Johnny 的 4 个条目。
最后,问题是:
有什么方法可以告诉 HBase 从 byte(x) 到 byte(x+y) [ x 是来自 discoName
的字节数和y 来自 personName
] 的字节数必须自动丢弃?
提前致谢!
最佳答案
首先要注意的是:如果您只有客户端访问权限,我帮不了您 :(
如果您有额外的访问权限,那么您可以查看以下建议,但默认回复是:如果这是您的访问模式,请针对它优化您的架构。
如果您需要以某种方式访问数据,请确保首先以这种方式编写。如果必须执行迁移,请使用 map-reduce API。
我可能会简单地添加一个表,该表只为每个访问者写一行 ministerOfSound 和一列。 (一般来说,您提出的模式听起来不太适合 HBase - 因为您有一堆单调增加行键的写入,如果对重复结果进行后处理确实是一个性能问题)
另一方面,如果这是一个临时查询,那么您可能想直接使用 mapreduce-API - 也许使用 Apache Spark-interconnect 并对数据执行“不同”调用。
将扫描用于分析查询不是我的做法。
如果您必须使用扫描来完成,那么我建议您实现协处理器。这些可以使用状态来增强 Filter,并且您可以在 Region Server 端投影 PrefixFilter's Scan 的结果。如果您是 CoProcessors 的新手,这里有一个介绍:HBase: The Definitive Guide .这要求您可以将 jar 部署到 RegionServer 类路径中。
但同样,如果您通过在那里进行不同的过滤来破坏您的客户端,您可能也会因为插入物上的热点而破坏您的区域。
作为最后一个选择:您可能想看看 Apache Phoenix,看看是否可以将您的行键强制转换为一个架构,您可以从该架构中对行键的前两部分执行不同的选择。这显然需要您在 rowkey 中有分隔符,或者至少是固定长度。
关于HBase 扫描 - RowKey 过滤器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42673146/
使用 C# (VS2008) 和 WIA - 扫描到 TIFF 格式; 当我在平板或文档进纸器上使用扫描仪扫描 1 页时,该方法执行没有任何问题。当我将多个表单加载到进纸器时,扫描第一页后执行停止(保
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
给定一个列表 :: [(Foo, Bar)] ,我想在 Bar 上执行 scanl1 s,但保留他们的 Foo “标签”。 IE。我想要一个类型为 :: [(a, b)] -> ([b] -> [c]
我有一个 HBase 表,我需要从多个范围获取结果。例如,我可能需要从不同范围获取数据,例如第 1-6 行、100-150..... 我知道对于每次扫描,我可以定义开始行和停止行。但是如果我有 6 个
我看到了这段代码。我是 C 语言的新手,所以请原谅。 while下面的循环将继续循环 if i = SIZE,则 == 是无关紧要的,因为它根本不会被执行。如果 i 小于 SIZE 那么 scanf(
这是一个关于编译过程的相当技术性的问题ABAP代码。 我知道有ABAP解析器和扫描器类实际上调用 C 内核函数来完成实际工作。然后就是代码补全事务的功能,该事务以 ABAP 列表或 XML 的形式返回
给定以下程序: int main(){ float x = non_det_float(); float y = NAN; if (isnan(y) && x == 1.0f){
我在工作中使用由供应商生成的二维码。实际上我需要通过网站手动记录所有这些项目。 QR 码包含所有这些数据,所以我想创建一个自动执行操作的应用。 例如,二维码表示“AAA|BBB|CCC|123”。我想
我有一个像这样的字符串:@"ololo width: 350px jijiji width:440px ... text=12... "我想将@"width: "之后的所有数字替换为280。所以在扫描
我在玩 scanf 时遇到了一个小问题……更具体地说,我想读取整个输入,然后忽略其余部分。让我告诉你我的意思: #include int main(void) { int number_of
我正在使用 matlab/octave 创建扫描/线性调频信号,我的结束信号似乎以错误的频率结束。我该如何修复它,以便信号以正确的频率结束。 PS:我不能在 Octave 音程中使用 chirp 命令
我正在寻找一个可以扫描 WiFi 网络并打印所有 SSID 的程序。我试过 scapy 但我失败了。我正在使用 pyCharm 编辑器。 我试过这段代码: from scapy.all import
概述 Linux 完全是用于大型服务器的最流行和最安全的操作系统之一。尽管它被广泛使用,但它仍然容易受到网络攻击。黑客以服务器为目标,窃取有价值的信息。所以迫切需要开发反黑客方法来应对安全漏洞和恶
如何获取我的 Git 存储库的某种统计信息? 我目前在 BitBucket 中托管 Git 存储库,想查找以下详细信息: 提交总数 使用过的编程语言 每种编程语言的总代码行数 您认为这可以实现吗?还是
我目前正在使用以下代码来扫描作为申请表的一部分上传的文件: $safe_path = escapeshellarg($dir . $file); $command = '/usr/bin/clamsc
我在存储库中有十几个项目。存储库结构如下所示: / ------- + project1 +------- trunk +------- tags +----
我正在使用 Dynamo DB 并想使用过滤器扫描一个表。例如,是否可以使用全局二级索引仅扫描表中的特定行? 最佳答案 这不可能!扫描始终针对基表中的所有行,当您扫描索引表作为响应时,您将仅获得该索引
我正在尝试从这里使用 SOLStumbler:Accessing & Using the MobileWiFi.framework扫描 wifi 网络。我知道苹果不支持这一点,但它是用于教育目的和实验
我知道 iPhone 蓝牙功能在 3.0 之前无法通过 SDK 访问,但是需要多长时间才能找到该区域的设备?它取决于该区域的设备数量吗?如果范围内有大约 5 个设备,扫描发现所有设备是否需要花费 30
我正在使用Elasticsearch 6.2,并且有一些查询可以分析大量文档。我正在对索引内的一个字段进行排序。 Elasticsearch检查10.000个文档(默认配置值),然后将它们分页返回。
我是一名优秀的程序员,十分优秀!