8-5 HBase 开发:使用Java操作HBase

目录

第一关:

命令行:

代码:

第二关:添加数据

命令行:

代码:

第三关:获取数据

命令行:

代码:

第四关:

代码:


第一关:

命令行:

start-dfs.sh

start-hbase.sh

hadoop fs -ls /hbase

代码:

HBase中创建表dept,emp,列都为:data

Configuration config = HBaseConfiguration.create();

//使用create()静态方法就可以得到Configuration对象

Connection connection = ConnectionFactory.createConnection(config);

 //config为前文的配置对象

Admin admin = connection.getAdmin();                   //使用连接对象获取Admin对象

TableName tableName1 = TableName.valueOf("dept");         //定义表名

TableName tableName2 = TableName.valueOf("emp");  

HTableDescriptor htd1 = new HTableDescriptor(tableName1);           //定义表对象

HTableDescriptor htd2 = new HTableDescriptor(tableName2);    

HColumnDescriptor hcd1 = new HColumnDescriptor("data");      //定义列族对象

HColumnDescriptor hcd2 = new HColumnDescriptor("data");

htd.addFamily(hcd1); //添加

htd.addFamily(hcd2);

admin.createTable(htd1);//创建表

admin.createTable(htd2);

第二关:添加数据

命令行:

start-dfs.sh

start-hbase.sh

hadoop fs -ls /hbase

stop-dfs.sh

stop-hbase.sh

代码:

在HBase中创建表tb_step2,列簇都为:data,添加数据:

行号分别为:row1,row2;

列名分别为:1,2;

值分别为:张三丰,张无忌。

//创建表

Configuration config = HBaseConfiguration.create();

Connection connection = ConnectionFactory.createConnection(config);

Admin admin = connection.getAdmin();                   //使用连接对象获取Admin对象



TableName tableName = TableName.valueOf("tb_step2");           //定义表名

HTableDescriptor htd = new HTableDescriptor(tableName);        //定义表对象

HColumnDescriptor hcd = new HColumnDescriptor("data");  //定义列族对象

htd.addFamily(hcd); //添加

admin.createTable(htd);//创建表
//添加数据:

Table table = connection.getTable(tableName);//获取Table对象

try {

    byte[] row1=Bytes.toBytes("row1");

            byte[] row2=Bytes.toBytes("row2");

            Put put1=new Put(row1);

            Put put2=new Put(row2);

            byte[] columnFamily=Bytes.toBytes("data");

            byte[] qualifier1=Bytes.toBytes(String.valueOf(1));

            byte[] qualifier2=Bytes.toBytes(String.valueOf(2));

            byte[] value1=Bytes.toBytes("张三丰");

            byte[] value2=Bytes.toBytes("张无忌");

            put1.addColumn(columnFamily, qualifier1, value1);;

            put2.addColumn(columnFamily,qualifier2,value2);

            table.put(put1);

            table.put(put2);

} finally {

    //使用完了要释放资源

    table.close();

}

第三关:获取数据

命令行:

start-dfs.sh

start-hbase.sh

hadoop fs -ls /hbase

输出t_step3表中行号为row1,列族为data:1的值(以utf-8编码),

输出table_step3表中所有行的行名称(因为直接输出scannerResult会带有时间戳,所以输出行名方便测评)。

代码:

Configuration config = HBaseConfiguration.create();

 Connection connection = ConnectionFactory.createConnection(config);

 Admin admin = connection.getAdmin();

 TableName tableName = TableName.valueOf("t_step3");

 Table table = connection.getTable(tableName);

#获取指定行的数据

//获取数据

Get get = new Get(Bytes.toBytes("row1"));    //定义get对象

Result result = table.get(get);            //通过table对象获取数据

System.out.println("Result: " + result);

byte[] valueBytes = result.getValue(Bytes.toBytes("data"), Bytes.toBytes("1"));

String valueStr = new String(valueBytes,"utf-8");

System.out.println("value:" + valueStr);

#扫描表中的数据

Scan scan = new Scan();

ResultScanner scanner = table.getScanner(scan);

try {

    for (Result scannerResult: scanner) {

        System.out.println("Scan: " + scannerResult);

         byte[] row = scannerResult.getRow();

         System.out.println("rowName:" + new String(row,"utf-8"));

    }

} finally {

    scanner.close();

}

第四关:

代码:

Configuration config = HBaseConfiguration.create();

 Connection connection = ConnectionFactory.createConnection(config);

 Admin admin = connection.getAdmin();

 TableName tableName = TableName.valueOf("t_step4");

 admin.disableTable(tableName);

 admin.deleteTable(tableName);

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: HBase是一个分布式的、面向列的NoSQL数据库,它是建立在Hadoop之上的。使用Java操作HBase可以通过HBase提供的Java API来实现。Java API提供了一系列的类和接口,可以用来连接HBase集群、创建表、插入数据、查询数据等操作。具体的操作步骤如下: 1. 引入HBaseJava API依赖包,可以通过Maven或手动下载方式获取。 2. 创建HBase的配置对象,设置HBase集群的Zookeeper地址和端口号。 3. 创建HBase的连接对象,通过配置对象和连接对象来连接HBase集群。 4. 创建HBase表,通过HBaseAdmin类的createTable方法来创建表。 5. 插入数据,通过Put类来封装数据,然后通过Table类的put方法来插入数据。 6. 查询数据,通过Get类来封装查询条件,然后通过Table类的get方法来查询数据。 7. 删除数据,通过Delete类来封装删除条件,然后通过Table类的delete方法来删除数据。 8. 闭连接,通过Connection类的close方法来闭连接。 以上就是使用Java操作HBase的基本步骤,需要注意的是,在使用HBase时需要考虑数据的一致性和可靠性,同时需要合理设计表结构和数据存储方式。 ### 回答2: HBase是一种分布式的非系型数据库,它被广泛应用于大规模数据存储和数据分析领域。HBase的特点在于高可靠性、高可扩展性、分布式计算能力强等优点,可以很好地处理海量数据。 HBase开发语言支持Java、Python等多种语言,使用Java操作HBase时,需要使用HBase提供的Java API,通过Java编写代码来实现对HBase操作操作HBase可以分为连接HBase、创建表、插入数据、查询数据、删除数据、闭连接等步骤。 1. 连接HBase 通过使用HBase提供的Configuration类,可以设置连接HBase所需的配置信息,包括zk连接地址、端口号等。创建完Configuration对象后,通过ConnectionFactory来获取连接HBase的Connection对象。 Configuration conf = HBaseConfiguration.create(); conf.set("hbase.zookeeper.quorum", "192.168.1.100"); conf.set("hbase.zookeeper.property.clientPort", "2181"); Connection conn = ConnectionFactory.createConnection(conf); 2. 创建表 通过Connection对象,可以使用Admin来操作HBase,创建表需要先创建TableDescriptor和ColumnFamilyDescriptor对象,然后通过Admin.createTable()方法来创建表。 Admin admin = conn.getAdmin(); TableName tableName = TableName.valueOf("test_table"); TableDescriptorBuilder tableDescriptorBuilder = TableDescriptorBuilder.newBuilder(tableName); ColumnFamilyDescriptor columnFamilyDescriptor = ColumnFamilyDescriptorBuilder.newBuilder(Bytes.toBytes("test_family")).build(); TableDescriptor tableDescriptor = tableDescriptorBuilder.setColumnFamily(columnFamilyDescriptor).build(); admin.createTable(tableDescriptor); admin.close(); 3. 插入数据 插入数据需要先创建Put对象,并将需要插入的数据通过AddColumn()方法添加到Put对象中,然后通过Table.put()方法将数据插入到表中。 Table table = conn.getTable(tableName); Put put = new Put(Bytes.toBytes("row_key")); put.addColumn(Bytes.toBytes("test_family"), Bytes.toBytes("test_qualifier"), Bytes.toBytes("test_value")); table.put(put); table.close(); 4. 查询数据 查询数据需要先创建Get对象,然后通过Table.get()方法来获取数据。可以通过addColumn()方法指定需要获取的列。 Get get = new Get(Bytes.toBytes("row_key")); get.addColumn(Bytes.toBytes("test_family"), Bytes.toBytes("test_qualifier")); Result result = table.get(get); byte[] resultValue = result.getValue(Bytes.toBytes("test_family"), Bytes.toBytes("test_qualifier")); 5. 删除数据 删除数据需要先创建Delete对象,指定需要删除的行和列,然后通过Table.delete()方法来执行删除操作。 Delete delete = new Delete(Bytes.toBytes("row_key")); delete.addColumn(Bytes.toBytes("test_family"), Bytes.toBytes("test_qualifier")); table.delete(delete); 6. 闭连接 操作HBase后需要闭连接以释放资源。 table.close(); admin.close(); conn.close(); 综上所述,使用Java操作HBase需要掌握HBaseJava API以及相操作步骤。通过以上代码示例,可以更好地理解JavaHBase中的应用。 ### 回答3: HBase是Apache Hadoop生态系统中的一种面向列的数据库系统,它能够提供低延迟的实时读写能力以及可扩展性和容错性。Java作为一种流行的编程语言,可以被用来操作HBase数据库系统。下面是使用Java操作HBase的一些常见操作和案例。 1. 连接HBase:在Java中,我们可以使用HBaseConfiguration类来创建连接HBase的配置信息。使用HBaseAdmin类可以验证HBase数据库是否可用,如下所示: ``` Configuration conf = HBaseConfiguration.create(); conf.set("hbase.zookeeper.quorum", "localhost"); HBaseAdmin admin = new HBaseAdmin(conf); boolean availability = admin.isMasterRunning(); ``` 2. 创建表格:可以使用HTableDescriptor和HColumnDescriptor类来创建HBase表格: ``` Configuration conf = HBaseConfiguration.create(); conf.set("hbase.zookeeper.quorum", "localhost"); HBaseAdmin admin = new HBaseAdmin(conf); HTableDescriptor tableDesc = new HTableDescriptor("mytable"); HColumnDescriptor familyDesc = new HColumnDescriptor("myfamily"); tableDesc.addFamily(familyDesc); admin.createTable(tableDesc); ``` 3. 插入数据:HBase的数据是基于行和列族的,可以使用Put类来将数据插入HBase的表中。可以使用HBase shell中的put命令来插入数据,而Java代码如下: ``` Configuration conf = HBaseConfiguration.create(); conf.set("hbase.zookeeper.quorum", "localhost"); HTable table = new HTable(conf, "mytable"); Put put = new Put(Bytes.toBytes("row1")); put.add(Bytes.toBytes("myfamily"), Bytes.toBytes("mycolumn"), Bytes.toBytes("myvalue")); table.put(put); ``` 4. 查询数据:HBase提供了多种查询方式,如Get、Scan和Filter等。使用Get查询可以根据行键来查询指定行的数据,如下所示: ``` Configuration conf = HBaseConfiguration.create(); conf.set("hbase.zookeeper.quorum", "localhost"); HTable table = new HTable(conf, "mytable"); Get get = new Get(Bytes.toBytes("row1")); Result result = table.get(get); byte[] value = result.getValue(Bytes.toBytes("myfamily"), Bytes.toBytes("mycolumn")); ``` 5. 删除数据:可以使用Delete类来删除指定的行或列族,如下所示: ``` Configuration conf = HBaseConfiguration.create(); conf.set("hbase.zookeeper.quorum", "localhost"); HTable table = new HTable(conf, "mytable"); Delete delete = new Delete(Bytes.toBytes("row1")); delete.deleteColumn(Bytes.toBytes("myfamily"), Bytes.toBytes("mycolumn")); table.delete(delete); ``` 综上所述,以上是使用Java操作HBase的一些基本操作和案例,HBaseJava API提供了许多高级功能,包括复杂的过滤查询、多版本控制和扫描器等,使其成为处理大量数据的优秀工具。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值