Hbase rest api 多次插入
Hbase rest api multiple inserts
我们计划使用 hbase rest api 执行插入到 hbase table 并且想知道是否有办法将多个列插入到单个列族甚至多个列中家庭在一个单一的电话。
如果不是,因为我们计划为特定记录(行)插入大约 100 多个列,这导致我们对单个行条目进行 100 多次调用
您可以在单个 PUT 操作中为 single/multiple 列族插入多个列。 --data
payload包含key
和CellSet
,CellSet包含cf:columnname
的base64编码值,$
包含列值的base64编码值。
例如:
{ "Row":[
{
"key":"d3d3LnNvbWVzaXRlLmNvbQ==",
"Cell":[
{
"column":"QXV0aG9yczp0ZXN0MQ==", // It can be cf1:name
"$":"c29tZURhdGE="
},
{
"column":"QXV0aG9yczp0ZXN0Mg==", // It can be cf2:address
"$":"bW9yZURhdGE="
}
]
}
]
}
最终的 curl 命令将如下所示:
curl -vi -X PUT \
-H "Accept: text/json" \
-H "Content-Type: text/json" \
-d '{"Row":[{"key":"d3d3LnNvbWVzaXRlLmNvbQ==","Cell":[{"column":"QXV0aG9yczp0ZXN0MQ==","$":"c29tZURhdGE="},{"column":"QXV0aG9yczp0ZXN0Mg==","$":"bW9yZURhdGE="}]}]}' \
"localhost:20550/table/rowkey"
我们计划使用 hbase rest api 执行插入到 hbase table 并且想知道是否有办法将多个列插入到单个列族甚至多个列中家庭在一个单一的电话。
如果不是,因为我们计划为特定记录(行)插入大约 100 多个列,这导致我们对单个行条目进行 100 多次调用
您可以在单个 PUT 操作中为 single/multiple 列族插入多个列。 --data
payload包含key
和CellSet
,CellSet包含cf:columnname
的base64编码值,$
包含列值的base64编码值。
例如:
{ "Row":[
{
"key":"d3d3LnNvbWVzaXRlLmNvbQ==",
"Cell":[
{
"column":"QXV0aG9yczp0ZXN0MQ==", // It can be cf1:name
"$":"c29tZURhdGE="
},
{
"column":"QXV0aG9yczp0ZXN0Mg==", // It can be cf2:address
"$":"bW9yZURhdGE="
}
]
}
]
}
最终的 curl 命令将如下所示:
curl -vi -X PUT \
-H "Accept: text/json" \
-H "Content-Type: text/json" \
-d '{"Row":[{"key":"d3d3LnNvbWVzaXRlLmNvbQ==","Cell":[{"column":"QXV0aG9yczp0ZXN0MQ==","$":"c29tZURhdGE="},{"column":"QXV0aG9yczp0ZXN0Mg==","$":"bW9yZURhdGE="}]}]}' \
"localhost:20550/table/rowkey"