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

相关文章

Java方法重载与重写之同名方法的双面魔法(最新整理)

《Java方法重载与重写之同名方法的双面魔法(最新整理)》文章介绍了Java中的方法重载Overloading和方法重写Overriding的区别联系,方法重载是指在同一个类中,允许存在多个方法名相同... 目录Java方法重载与重写:同名方法的双面魔法方法重载(Overloading):同门师兄弟的不同绝

Spring配置扩展之JavaConfig的使用小结

《Spring配置扩展之JavaConfig的使用小结》JavaConfig是Spring框架中基于纯Java代码的配置方式,用于替代传统的XML配置,通过注解(如@Bean)定义Spring容器的组... 目录JavaConfig 的概念什么是JavaConfig?为什么使用 JavaConfig?Jav

Java数组动态扩容的实现示例

《Java数组动态扩容的实现示例》本文主要介绍了Java数组动态扩容的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1 问题2 方法3 结语1 问题实现动态的给数组添加元素效果,实现对数组扩容,原始数组使用静态分配

Java中ArrayList与顺序表示例详解

《Java中ArrayList与顺序表示例详解》顺序表是在计算机内存中以数组的形式保存的线性表,是指用一组地址连续的存储单元依次存储数据元素的线性结构,:本文主要介绍Java中ArrayList与... 目录前言一、Java集合框架核心接口与分类ArrayList二、顺序表数据结构中的顺序表三、常用代码手动

JAVA项目swing转javafx语法规则以及示例代码

《JAVA项目swing转javafx语法规则以及示例代码》:本文主要介绍JAVA项目swing转javafx语法规则以及示例代码的相关资料,文中详细讲解了主类继承、窗口创建、布局管理、控件替换、... 目录最常用的“一行换一行”速查表(直接全局替换)实际转换示例(JFramejs → JavaFX)迁移建

Spring Boot Interceptor的原理、配置、顺序控制及与Filter的关键区别对比分析

《SpringBootInterceptor的原理、配置、顺序控制及与Filter的关键区别对比分析》本文主要介绍了SpringBoot中的拦截器(Interceptor)及其与过滤器(Filt... 目录前言一、核心功能二、拦截器的实现2.1 定义自定义拦截器2.2 注册拦截器三、多拦截器的执行顺序四、过

Go异常处理、泛型和文件操作实例代码

《Go异常处理、泛型和文件操作实例代码》Go语言的异常处理机制与传统的面向对象语言(如Java、C#)所使用的try-catch结构有所不同,它采用了自己独特的设计理念和方法,:本文主要介绍Go异... 目录一:异常处理常见的异常处理向上抛中断程序恢复程序二:泛型泛型函数泛型结构体泛型切片泛型 map三:文

JAVA线程的周期及调度机制详解

《JAVA线程的周期及调度机制详解》Java线程的生命周期包括NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING和TERMINATED,线程调度依赖操作系统,采用抢占... 目录Java线程的生命周期线程状态转换示例代码JAVA线程调度机制优先级设置示例注意事项JAVA线程

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

Java使用Spire.Doc for Java实现Word自动化插入图片

《Java使用Spire.DocforJava实现Word自动化插入图片》在日常工作中,Word文档是不可或缺的工具,而图片作为信息传达的重要载体,其在文档中的插入与布局显得尤为关键,下面我们就来... 目录1. Spire.Doc for Java库介绍与安装2. 使用特定的环绕方式插入图片3. 在指定位