美文网首页
HBase开发 之 数据操作

HBase开发 之 数据操作

作者: 诺之林 | 来源:发表于2020-12-11 16:48 被阅读0次

本文的主线 项目 => 新增 => 查询 => 详情 => 删除

本文的示例代码参考hbase-data

启动HBase服务参考HBase搭建 之 单机模式

项目

spring init -b=2.2.10.RELEASE -j=1.8 -l=java -d=web --build=gradle hbase-data && cd hbase-data

vim build.gradle
dependencies {
    implementation('org.springframework.boot:spring-boot-starter-web') {
        exclude group: 'org.springframework.boot', module: 'spring-boot-starter-logging'
    }
    implementation('org.apache.hbase:hbase-client:2.2.6')
    testImplementation('org.springframework.boot:spring-boot-starter-test') {
        exclude group: 'org.junit.vintage', module: 'junit-vintage-engine'
    }
}

新增

vim src/main/java/com/example/hbasedata/DataController.java
package com.example.hbasedata;

import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.*;
import org.apache.hadoop.hbase.util.Bytes;
import org.springframework.web.bind.annotation.*;

import java.io.IOException;
import java.util.Map;

@RestController
@RequestMapping
public class DataController {
    @PostMapping("/{tableName}")
    public String create(@PathVariable("tableName") String tableName,
                         @RequestBody Map<String, String> data) throws IOException {
        String rowKey = data.get("rowKey");
        String familyName = data.get("familyName");
        String qualifier = data.get("qualifier");
        String value = data.get("value");

        Connection connection = ConnectionFactory.createConnection();
        Admin admin = connection.getAdmin();

        if (admin.tableExists(TableName.valueOf(tableName))) {
            Table table = connection.getTable(TableName.valueOf(tableName));
            Put put = new Put(Bytes.toBytes(rowKey));
            put.addColumn(Bytes.toBytes(familyName), Bytes.toBytes(qualifier), Bytes.toBytes(value));
            table.put(put);
        }

        return data.toString();
    }
}
./bin/hbase shell

create 'test', 'cf'
./gradlew bootrun

curl -X POST  -H 'Content-Type: application/json' -d '{"rowKey" : "row1","familyName" : "cf","qualifier" : "a","value" : "value1"}' http://localhost:8080/test
# {rowKey=row1, familyName=cf, qualifier=a, value=value1}

curl -X POST  -H 'Content-Type: application/json' -d '{"rowKey" : "row2","familyName" : "cf","qualifier" : "a","value" : "value2"}' http://localhost:8080/test
# {rowKey=row2, familyName=cf, qualifier=a, value=value2}
./bin/hbase shell

scan 'test'
# row1                                                            column=cf:a, timestamp=1607673937167, value=value1
# row2                                                            column=cf:a, timestamp=1607673943275, value=value2

查询

vim src/main/java/com/example/hbasedata/DataController.java
package com.example.hbasedata;

import org.apache.hadoop.hbase.Cell;
import org.apache.hadoop.hbase.CellUtil;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.*;
import org.apache.hadoop.hbase.util.Bytes;
import org.springframework.web.bind.annotation.*;

import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;

@RestController
@RequestMapping
public class DataController {
    // 省略了未修改代码
    @GetMapping("/{tableName}")
    public List<String> index(@PathVariable("tableName") String tableName,
                              @RequestParam("familyName") String familyName,
                              @RequestParam("qualifier") String qualifier) throws IOException {
        Connection connection = ConnectionFactory.createConnection();
        Admin admin = connection.getAdmin();

        List<String> dataList = new ArrayList<>();
        if (admin.tableExists(TableName.valueOf(tableName))) {
            Table table = connection.getTable(TableName.valueOf(tableName));
            ResultScanner scanner = table.getScanner(new Scan());
            for (Result result : scanner) {
                for (Cell cell : result.getColumnCells(Bytes.toBytes(familyName), Bytes.toBytes(qualifier))) {
                    dataList.add(Bytes.toString(CellUtil.cloneValue(cell)));
                }
            }
        }
        return  dataList;
    }
}
./gradlew bootrun

curl http://localhost:8080/test?familyName=cf&qualifier=a
# ["value1","value2"]

详情

vim src/main/java/com/example/hbasedata/DataController.java
package com.example.hbasedata;

import org.apache.hadoop.hbase.Cell;
import org.apache.hadoop.hbase.CellUtil;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.*;
import org.apache.hadoop.hbase.util.Bytes;
import org.springframework.web.bind.annotation.*;

import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;

@RestController
@RequestMapping
public class DataController {
    // 省略了未修改代码
    @GetMapping("/{tableName}/{rowKey}")
    public List<String> show(@PathVariable("tableName") String tableName,
                             @PathVariable("rowKey") String rowKey,
                             @RequestParam("familyName") String familyName,
                             @RequestParam("qualifier") String qualifier) throws IOException {
        Connection connection = ConnectionFactory.createConnection();
        Admin admin = connection.getAdmin();

        List<String> columnList = new ArrayList<String>();
        if (admin.tableExists(TableName.valueOf(tableName))) {
            Table table = connection.getTable(TableName.valueOf(tableName));
            Get get = new Get(Bytes.toBytes(rowKey));
            Result result = table.get(get);
            for (Cell cell : result.getColumnCells(Bytes.toBytes(familyName), Bytes.toBytes(qualifier))) {
                columnList.add(Bytes.toString(CellUtil.cloneValue(cell)));
            }
        }
        return columnList;
    }
}
./gradlew bootrun

curl http://localhost:8080/test/row1?familyName=cf&qualifier=a
# ["value1"]

删除

vim src/main/java/com/example/hbasedata/DataController.java
package com.example.hbasedata;

import org.apache.hadoop.hbase.Cell;
import org.apache.hadoop.hbase.CellUtil;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.*;
import org.apache.hadoop.hbase.util.Bytes;
import org.springframework.web.bind.annotation.*;

import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;

@RestController
@RequestMapping
public class DataController {
    // 省略了未修改代码
    @DeleteMapping("/{tableName}/{rowKey}")
    public String show(@PathVariable("tableName") String tableName,
                             @PathVariable("rowKey") String rowKey) throws IOException {
        Connection connection = ConnectionFactory.createConnection();
        Admin admin = connection.getAdmin();

        if (admin.tableExists(TableName.valueOf(tableName))) {
            Table table = connection.getTable(TableName.valueOf(tableName));
            Delete delete = new Delete(Bytes.toBytes(rowKey));
            table.delete(delete);
        }
        return rowKey;
    }
}
./gradlew bootrun

curl -X DELETE http://localhost:8080/test/row1
# row1

curl -X DELETE http://localhost:8080/test/row2
# row2
./bin/hbase shell

scan 'test'
# 0 row(s)

参考

相关文章

  • HBase开发 之 数据操作

    本文的主线 项目 => 新增 => 查询 => 详情 => 删除 本文的示例代码参考hbase-data[http...

  • HBase | 相对于rdbms

    相对于rdbms hbase vs rdbms 数据类型HBase只有简单的字符串类型 数据操作HBase只有简单...

  • HBase开发 之 表操作

    本文的主线 项目 => 新增 => 列表 => 详情 => 删除 本文的示例代码参考hbase-table[htt...

  • HBase开发 之 批量操作

    本文的主线 项目 => 新增 => 删除 本文的示例代码参考hbase-batch[http://git.nuoz...

  • 六、HBase写入流程

    1、HBase写入流程 HBase服务端没有提供update,delete接口,HBase中对数据的更新、删除操作...

  • HBase相关文章索引(1)

    工具资源 利用phoenix进行Hbase数据访问 在SQUIRREL中使用PHOENIX操作HBASE——创建表...

  • HBase数据操作

    1、 HBase shell操作 在命令行中执行hbase shell就进入了hbase shell操作模式,可以...

  • HBase Shell操作

    HBase Shell是HBase的命令行工具,提供了对HBase的管理操作,可以对HBase中的表进行数据的增、...

  • HBase 数据模型

    理解 HBase 的数据模型,能够更好的理解 HBase 针对 Region 的操作(Split、Compact等...

  • hbase 服务化文档

    hbase 单独抽出平台 说白了 就是解决 hbase put ,scan 操作 ,开发比较吃力 ,不优雅等问题。...

网友评论

      本文标题:HBase开发 之 数据操作

      本文链接:https://www.haomeiwen.com/subject/zsmkgktx.html