hbase scan的java操作

2024-06-24 07:38
文章标签 java 操作 hbase scan

本文主要是介绍hbase scan的java操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

public class HbaseTest {public static void main(String[] args) throws Exception {//构建基本信息String table = "t_userBehavior2";final TableName tableName = TableName.valueOf(table);final HTable hTable = new HTable(tableName, HBaseUtil.getConnection());final Scan scan = new Scan();//查询出小于某个rk的全部数据System.out.println("小于等于DD4400000047344000007497818085B0的行");Filter filter1 = new RowFilter(CompareFilter.CompareOp.LESS_OR_EQUAL,new BinaryComparator("DD4400000047344000007497818085B0".getBytes()));scan.setFilter(filter1);ResultScanner scanner1 = hTable.getScanner(scan);for (Result res : scanner1) {System.out.println(res);}scanner1.close();System.out.println("--------------------------------------------------------------------");//正则匹配rkSystem.out.println("正则获取结尾为85B0的行");final RowFilter filter2 = new RowFilter(CompareFilter.CompareOp.EQUAL, new RegexStringComparator(".*85B0"));scan.setFilter(filter2);final ResultScanner scanner2 = hTable.getScanner(scan);for (Result res : scanner2) {System.out.println(res);}scanner2.close();System.out.println("--------------------------------------------------------------------");//rk包含某些字符串的所有行System.out.println("包含有DD4400000047的行");Filter filter3 = new RowFilter(CompareFilter.CompareOp.EQUAL,new SubstringComparator("DD4400000047"));scan.setFilter(filter3);ResultScanner scanner3 = hTable.getScanner(scan);for (Result res : scanner3) {System.out.println(res);}scanner3.close();System.out.println("--------------------------------------------------------------------");//判断rk的开头信息的所有行System.out.println("开头是DD4400的");Filter filter4 = new RowFilter(CompareFilter.CompareOp.EQUAL,new BinaryPrefixComparator("DD4400".getBytes()));scan.setFilter(filter4);ResultScanner scanner4 = hTable.getScanner(scan);for (Result res : scanner4) {System.out.println(res);}scanner3.close();System.out.println("----------------------------------------------------");/***RowFilter用于过滤row key,过滤的条件如下:Operator   DescriptionLESS   小于LESS_OR_EQUAL  小于等于EQUAL  等于NOT_EQUAL  不等于GREATER_OR_EQUAL   大于等于GREATER    大于NO_OP  排除所有Comparator Description比较器:BinaryComparator   使用Bytes.compareTo()比较BinaryPrefixComparator 和BinaryComparator差不多,从前面开始比较NullComparator Does not compare against an actual value but whether a given one is null, or not  null.BitComparator  Performs a bitwise comparison, providing a BitwiseOp class with OR, and XORoperators.RegexStringComparator  正则表达式SubstringComparator    把数据当成字符串,用contains()来判断*scan.setFilter(new PrefixFilter(rowPrifix.getBytes()));根据rk的前缀来进行过滤出所有的行*设定限制范围,查询出该范围内的所有行scan.setStartRow(getBytes(startRow));scan.setStopRow(getBytes(stopRow));*/scan.setStartRow(Bytes.toBytes("000000000"));//        scan.setStopRow(Bytes.toBytes("235959999"));
//        scan.setFilter(new PrefixFilter(rowPrifix.getBytes()));ResultScanner rs = hTable.getScanner(scan);for (Result r : rs) {KeyValue[] kv = r.raw();for (int i = 0; i < kv.length; i++) {final String rk = new String(kv[i].getRow());final Result resut = HBaseUtil.getRow(table, rk.getBytes());final List<Cell> cellList = resut.listCells();for (Cell cell : cellList) {final String value = new String(cell.getValue());System.out.println(value);}System.out.print(new String(kv[i].getRow()) + "  ");System.out.print(new String(kv[i].getFamily()) + ":");System.out.print(new String(kv[i].getQualifier()) + "  ");System.out.print(kv[i].getTimestamp() + "  ");System.out.println(new String(kv[i].getValue()));}}}}作者:会飞的蜗牛66666链接:https://www.jianshu.com/p/1da9fe1b2afe来源:简书简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

 

这篇关于hbase scan的java操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1089533

相关文章

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

JavaSE正则表达式用法总结大全

《JavaSE正则表达式用法总结大全》正则表达式就是由一些特定的字符组成,代表的是一个规则,:本文主要介绍JavaSE正则表达式用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录常用的正则表达式匹配符正则表China编程达式常用的类Pattern类Matcher类PatternSynta

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

java实现docker镜像上传到harbor仓库的方式

《java实现docker镜像上传到harbor仓库的方式》:本文主要介绍java实现docker镜像上传到harbor仓库的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 前 言2. 编写工具类2.1 引入依赖包2.2 使用当前服务器的docker环境推送镜像2.2

Java easyExcel实现导入多sheet的Excel

《JavaeasyExcel实现导入多sheet的Excel》这篇文章主要为大家详细介绍了如何使用JavaeasyExcel实现导入多sheet的Excel,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录1.官网2.Excel样式3.代码1.官网easyExcel官网2.Excel样式3.代码

Java MQTT实战应用

《JavaMQTT实战应用》本文详解MQTT协议,涵盖其发布/订阅机制、低功耗高效特性、三种服务质量等级(QoS0/1/2),以及客户端、代理、主题的核心概念,最后提供Linux部署教程、Sprin... 目录一、MQTT协议二、MQTT优点三、三种服务质量等级四、客户端、代理、主题1. 客户端(Clien

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr