首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySQL按位操作,布隆过滤器

MySQL按位操作,布隆过滤器
EN

Stack Overflow用户
提问于 2008-12-11 20:54:39
回答 6查看 15.1K关注 0票数 9

我想用MySQL实现一个bloom filter (另一个推荐的替代方案)。

问题如下:

假设我有一个存储8位整数的表,其中包含以下值:

代码语言:javascript
复制
1: 10011010
2: 00110101
3: 10010100
4: 00100110
5: 00111011
6: 01101010

我希望找到所有按位计算的结果,并如下所示:

代码语言:javascript
复制
00011000

结果应该是第1行和第5行。

然而,在我的问题中,它们不是8位整数,而是n位整数。如何存储,如何查询?速度是关键。

EN

回答 6

Stack Overflow用户

发布于 2008-12-11 21:45:08

创建一个包含int列的表(使用this link选择正确的int大小)。不要将数字存储为0和1的序列。

对于您的数据,它将如下所示:

代码语言:javascript
复制
number

154
53
148
38
59
106

你需要找到与24匹配的所有条目。

然后,您可以运行如下查询

代码语言:javascript
复制
SELECT * FROM test WHERE number & 24 = 24

如果你想避免在你的应用程序中转换成10个基数,你可以把它交给mysql:

代码语言:javascript
复制
INSERT INTO test SET number = b'00110101';

像这样搜索

代码语言:javascript
复制
SELECT bin(number) FROM test WHERE number & b'00011000' = b'00011000'
票数 19
EN

Stack Overflow用户

发布于 2008-12-14 05:37:13

为此,请考虑不使用MySQL。

首先,对于超过64位的表,可能没有内置的方法。您将不得不求助于用C编写的用户定义函数。

其次,每个查询都需要一个全表扫描,因为MySQL不能对您的查询使用索引。因此,除非您的表非常小,否则速度不会很快。

票数 8
EN

Stack Overflow用户

发布于 2008-12-17 18:23:36

切换到PostgreSQL并使用位(N)

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/360844

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档