Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
kvdb
rocksdb
提交
5363eb8a
R
rocksdb
项目概览
kvdb
/
rocksdb
11 个月 前同步成功
通知
0
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
rocksdb
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
5363eb8a
编写于
6月 19, 2014
作者:
E
Evan Shaw
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add a test for using compaction filters via the C API
上级
d72313a7
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
53 addition
and
0 deletion
+53
-0
db/c_test.c
db/c_test.c
+53
-0
未找到文件。
db/c_test.c
浏览文件 @
5363eb8a
...
@@ -154,6 +154,28 @@ static unsigned char FilterKeyMatch(
...
@@ -154,6 +154,28 @@ static unsigned char FilterKeyMatch(
return
fake_filter_result
;
return
fake_filter_result
;
}
}
// Custom compaction filter
static
void
CFilterDestroy
(
void
*
arg
)
{}
static
const
char
*
CFilterName
(
void
*
arg
)
{
return
"foo"
;
}
static
unsigned
char
CFilterFilter
(
void
*
arg
,
int
level
,
const
char
*
key
,
size_t
key_length
,
const
char
*
existing_value
,
size_t
value_length
,
char
**
new_value
,
size_t
*
new_value_length
,
unsigned
char
*
value_changed
)
{
if
(
key_length
==
3
)
{
if
(
memcmp
(
key
,
"bar"
,
key_length
)
==
0
)
{
return
1
;
}
else
if
(
memcmp
(
key
,
"baz"
,
key_length
)
==
0
)
{
*
value_changed
=
1
;
*
new_value
=
"newbazvalue"
;
*
new_value_length
=
11
;
return
0
;
}
}
return
0
;
}
// Custom merge operator
// Custom merge operator
static
void
MergeOperatorDestroy
(
void
*
arg
)
{
}
static
void
MergeOperatorDestroy
(
void
*
arg
)
{
}
static
const
char
*
MergeOperatorName
(
void
*
arg
)
{
static
const
char
*
MergeOperatorName
(
void
*
arg
)
{
...
@@ -407,6 +429,37 @@ int main(int argc, char** argv) {
...
@@ -407,6 +429,37 @@ int main(int argc, char** argv) {
rocksdb_filterpolicy_destroy
(
policy
);
rocksdb_filterpolicy_destroy
(
policy
);
}
}
StartPhase
(
"compaction_filter"
);
{
rocksdb_compactionfilter_t
*
cfilter
;
cfilter
=
rocksdb_compactionfilter_create
(
NULL
,
CFilterDestroy
,
CFilterFilter
,
CFilterName
);
// Create new database
rocksdb_close
(
db
);
rocksdb_destroy_db
(
options
,
dbname
,
&
err
);
rocksdb_options_set_compaction_filter
(
options
,
cfilter
);
db
=
rocksdb_open
(
options
,
dbname
,
&
err
);
CheckNoError
(
err
);
rocksdb_put
(
db
,
woptions
,
"foo"
,
3
,
"foovalue"
,
8
,
&
err
);
CheckNoError
(
err
);
CheckGet
(
db
,
roptions
,
"foo"
,
"foovalue"
);
rocksdb_put
(
db
,
woptions
,
"bar"
,
3
,
"barvalue"
,
8
,
&
err
);
CheckNoError
(
err
);
CheckGet
(
db
,
roptions
,
"bar"
,
"barvalue"
);
rocksdb_put
(
db
,
woptions
,
"baz"
,
3
,
"bazvalue"
,
8
,
&
err
);
CheckNoError
(
err
);
CheckGet
(
db
,
roptions
,
"baz"
,
"bazvalue"
);
// Force compaction
rocksdb_compact_range
(
db
,
NULL
,
0
,
NULL
,
0
);
// should have filtered bar, but not foo
CheckGet
(
db
,
roptions
,
"foo"
,
"foovalue"
);
CheckGet
(
db
,
roptions
,
"bar"
,
NULL
);
CheckGet
(
db
,
roptions
,
"baz"
,
"newbazvalue"
);
rocksdb_compactionfilter_destroy
(
cfilter
);
}
StartPhase
(
"merge_operator"
);
StartPhase
(
"merge_operator"
);
{
{
rocksdb_mergeoperator_t
*
merge_operator
;
rocksdb_mergeoperator_t
*
merge_operator
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录