最新java操作HBase(2),Java高级开发岗必问知识点

总结

至此,文章终于到了尾声。总结一下,我们谈论了简历制作过程中需要注意的以下三个部分,并分别给出了一些建议:

  1. 技术能力:先写岗位所需能力,再写加分能力,不要写无关能力;
  2. 项目经历:只写明星项目,描述遵循 STAR 法则;
  3. 简历印象:简历遵循三大原则:清晰,简短,必要,要有的放矢,不要海投;

以及最后为大家准备的福利时间:简历模板+Java面试题+热门技术系列教程视频

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

LESS_OR_EQUAL —— 小于等于

EQUAL —— 等于

NOT_EQUAL —— 不等于

GREATER_OR_EQUAL —— 大于等于

GREATER —— 大于

NO_OP —— 排除所有

专用过滤器

BinaryComparator —— 匹配完整字节数组,Bytes.compareTo(byte[])

BinaryPrefixComparator —— 匹配字节数组前缀
NullComparator —— 判断给定的是否为空
BitComparator —— 按位比较
RegexStringComparator —— 提供一个正则的比较器,仅支持 EQUAL 和非EQUAL
SubstringComparator —— 判断提供的子串是否出现在value中

  • 3.1、ResultScanner结果处理handleResultScanner
/**
 *	ResultScanner结果解析
 */
public void handleResultScanner(ResultScanner scanner) throws IOException {
	//因为ResultScanner类继承了迭代器
	//使用增强for循环遍历
	for (Result rs : scanner) {
	String id = Bytes.toString(rs.getRow());
	System.out.println("当前行的rowkey为:" + id);
	//继续增强for循环得到每一行中的每一个单元格(列)
	//获取一行中的所有单元格
	for (Cell cell : rs.listCells()) {
		//获取该单元格属于的列簇
		String family = Bytes.toString(CellUtil.cloneFamily(cell));
		//获取该单元格的列名
		String colName = Bytes.toString(CellUtil.cloneQualifier(cell));
		//获取该单元格的列值
		String value = Bytes.toString(CellUtil.cloneValue(cell));
		System.out.println(family + ":" + colName + "的值为:" + value);
	}
​
	String name = Bytes.toString(rs.getValue("info".getBytes(), "name".getBytes()));
	String age = Bytes.toString(rs.getValue("info".getBytes(), "age".getBytes()));
	String gender = Bytes.toString(rs.getValue("info".getBytes(), "gender".getBytes()));
	String clazz = Bytes.toString(rs.getValue("info".getBytes(), "clazz".getBytes()));
	System.out.println("学号:" + id + ",姓名:" + name + ",年龄:" + age + ",性别:" + gender + ",班级:" + clazz);
	
}
3.2、rowKey过滤器RowFilter
/**
 *  行键过滤器
 *  通过RowFilter与BinaryComparator过滤比rowKey 1500100010小的所有值出来
 */
@Test
public void RowFilter1(){
	try {
		//获取表的实例
        TableName students = TableName.valueOf("students");
        Table studentTable = conn.getTable(students);
​
		BinaryComparator binaryComparator = new BinaryComparator("1500100010".getBytes());
​
		//创建一个行键过滤器的对象
		RowFilter rowFilter = new RowFilter(CompareOperator.LESS, binaryComparator);
​
		Scan scan = new Scan();
		scan.setFilter(rowFilter);
​
		ResultScanner scanner = studentTable.getScanner(scan);
		handleResultScanner(scanner);
​
	} catch (IOException e) {
		e.printStackTrace();
	}
}
3.3、列族过滤器FamilyFilter
/**
 * 	通过FamilyFilter与SubstringComparator查询列簇名包含in的所有列簇下面的数据
 */
@Test
public void FamilyFilter1(){
	try {
		//获取表的实例
		TableName students = TableName.valueOf("students");
        Table studentTable = conn.getTable(students);
​
		//创建一个比较器对象
		//只要列簇名中包含了in,就把该列簇下的所有列查询出来
		SubstringComparator substringComparator = new SubstringComparator("in");
​
		//创建列簇过滤器
		FamilyFilter familyFilter = new FamilyFilter(CompareOperator.EQUAL, substringComparator);
​
		Scan scan = new Scan();
		scan.setFilter(familyFilter);
​
		//获取数据
		ResultScanner scanner = studentTable.getScanner(scan);
		handleResultScanner(scanner);
​
​
	} catch (IOException e) {
		e.printStackTrace();
	}
}

/**
 *	通过FamilyFilter与 BinaryPrefixComparator 过滤出列簇以i开头的列簇下的所有数据
 *
 */
@Test
public void FamilyFilter2(){
	try {
		//获取表的实例
		TableName students = TableName.valueOf("students");
        Table studentTable = conn.getTable(students);
​
		//创建前缀比较器
		BinaryPrefixComparator binaryPrefixComparator = new BinaryPrefixComparator("i".getBytes());
​
		//创建列簇过滤器
		FamilyFilter familyFilter = new FamilyFilter(CompareOperator.EQUAL, binaryPrefixComparator);
​
		Scan scan = new Scan();
		scan.setFilter(familyFilter);
​
		ResultScanner scanner = studentTable.getScanner(scan);
		handleResultScanner(scanner);
​
	} catch (IOException e) {
		e.printStackTrace();
	}
}
3.4、列过滤器QualifierFilter
/**
 * 通过QualifierFilter与SubstringComparator查询列名包含ge的列的值
 *
 */
@Test
public void QualifierFilter1(){
	try {
		//获取表的实例
		TableName students = TableName.valueOf("students");
        Table studentTable = conn.getTable(students);
​
		//创建包含比较器
		//age
		//gender
		SubstringComparator substringComparator = new SubstringComparator("ge");
​
		//创建一个列过滤器
		QualifierFilter qualifierFilter = new QualifierFilter(CompareOperator.EQUAL, substringComparator);
​
		Scan scan = new Scan();
		scan.setFilter(qualifierFilter);
​
		ResultScanner scanner = studentTable.getScanner(scan);
		handleResultScanner(scanner);
​
​
	} catch (IOException e) {
		e.printStackTrace();
	}
}

/**
 *
 * 通过QualifierFilter与SubstringComparator查询列名包含ge的列的值
 */
@Test
public void QualifierFilter2(){
	try {
		//获取表的实例
		TableName students = TableName.valueOf("students");
        Table studentTable = conn.getTable(students);
​
		SubstringComparator substringComparator = new SubstringComparator("am");
​
		//创建列过滤器
		QualifierFilter qualifierFilter = new QualifierFilter(CompareOperator.EQUAL, substringComparator);
​
		Scan scan = new Scan();
		scan.setFilter(qualifierFilter);
​
		ResultScanner scanner = studentTable.getScanner(scan);
		handleResultScanner(scanner);
​
	} catch (IOException e) {
		e.printStackTrace();
	}
}
3.5、列值过滤器ValueFilter
/**
 *	通过ValueFilter与BinaryPrefixComparator过滤出所有的cell中值以 "张" 开头的学生
 */
@Test
public void ValueFilter1() {
	try {
		//获取表的实例
		TableName students = TableName.valueOf("students");
        Table studentTable = conn.getTable(students);
​
		//创建前缀比较器
		BinaryPrefixComparator binaryPrefixComparator = new BinaryPrefixComparator("张".getBytes());
​
		//创建列值过滤器的对象
		ValueFilter valueFilter = new ValueFilter(CompareOperator.EQUAL, binaryPrefixComparator);
​
		Scan scan = new Scan();
		scan.setFilter(valueFilter);
​
		ResultScanner scanner = studentTable.getScanner(scan);
​
		//因为ResultScanner类继承了迭代器
		//使用增强for循环遍历
//            for (Result rs : scanner) {
//                String id = Bytes.toString(rs.getRow());
//                System.out.println("当前行的rowkey为:" + id);
//                //继续增强for循环得到每一行中的每一个单元格(列)
//                //获取一行中的所有单元格
//                for (Cell cell : rs.listCells()) {
//                    //获取该单元格属于的列簇
//                    String family = Bytes.toString(CellUtil.cloneFamily(cell));
//                    //获取该单元格的列名
//                    String colName = Bytes.toString(CellUtil.cloneQualifier(cell));
//                    //获取该单元格的列值
//                    String value = Bytes.toString(CellUtil.cloneValue(cell));
//                    System.out.println(family + ":" + colName + "的值为:" + value);
//                }
//            }
​
		handleResultScanner(scanner);
	} catch (IOException e) {
		e.printStackTrace();
	}
}

/**
 *	过滤出文科的学生,只会返回以文科开头的数据列,其他列的数据不符合条件,不会返回
 */
@Test
public void ValueFilter12(){
	try {
		//获取表的实例
		HTableInterface students = conn.getTable("students");
​
		//创建正则比较器
		RegexStringComparator regexStringComparator = new RegexStringComparator("^文科.*");
​
		//创建列值过滤器
		ValueFilter valueFilter = new ValueFilter(CompareFilter.CompareOp.EQUAL, regexStringComparator);
​
		Scan scan = new Scan();
		scan.setFilter(valueFilter);
​
		ResultScanner scanner = students.getScanner(scan);
		handleResultScanner(scanner);
​
​
	} catch (IOException e) {
		e.printStackTrace();
	}
}
3.6、单列值过滤器 SingleColumnValueFilter
/**
 * 单列值过滤器
 * SingleColumnValueFilter会返回满足条件的cell所在行的所有cell的值(即会返回一行数据)
 *
 * 通过SingleColumnValueFilter与查询文科班所有学生信息
 */
@Test
public void SingleColumnValueFilter(){
	try {
		//获取表的实例
		TableName students = TableName.valueOf("students");
        Table studentTable = conn.getTable(students);
​
		//创建一个正则比较器
		RegexStringComparator regexStringComparator = new RegexStringComparator("^文科.*");
​
		//创建单列值过滤器对象
		SingleColumnValueFilter singleColumnValueFilter = new SingleColumnValueFilter(
				"info".getBytes(),
				"clazz".getBytes(),
				CompareOperator.EQUAL,
				regexStringComparator
		);
​
		Scan scan = new Scan();
		scan.setFilter(singleColumnValueFilter);
​
		ResultScanner scanner = studentTable.getScanner(scan);
		handleResultScanner(scanner);
​
​
	} catch (IOException e) {
		e.printStackTrace();
	}
}
3.7、列值排除过滤器SingleColumnValueExcludeFilter
/**
 * 列值排除过滤器
 * 与SingleColumnValueFilter相反,会排除掉指定的列,其他的列全部返回
 *
 * 通过SingleColumnValueExcludeFilter与BinaryComparator查询文科一班所有学生信息,最终不返回clazz列
 */
@Test
public void SingleColumnValueExcludeFilter(){
	try {
		//获取表的实例
		TableName students = TableName.valueOf("students");
        Table studentTable = conn.getTable(students);
​
		//创建一个二进制比较器
		BinaryComparator binaryComparator = new BinaryComparator("文科一班".getBytes());
​
		//创建一个列值排除过滤器
		SingleColumnValueExcludeFilter singleColumnValueExcludeFilter = new SingleColumnValueExcludeFilter(
				"info".getBytes(),
				"clazz".getBytes(),
				CompareOperator.EQUAL,
				binaryComparator
		);
​
		Scan scan = new Scan();
		scan.setFilter(singleColumnValueExcludeFilter);
​
		ResultScanner scanner = studentTable.getScanner(scan);
		handleResultScanner(scanner);
​
​
	} catch (IOException e) {
		e.printStackTrace();
	}
}
3.8、rowKey前缀过滤器PrefixFilter
/**
 * rowkey前缀过滤器
 *
 * 通过PrefixFilter查询以150010008开头的所有前缀的rowkey
 */
@Test
public void PrefixFilter(){
	try {
		//获取表的实例
		TableName students = TableName.valueOf("students");
        Table studentTable = conn.getTable(students);
​
		//创建rowkey前缀过滤器
		PrefixFilter prefixFilter = new PrefixFilter("150010008".getBytes());
		Scan scan = new Scan();
​
		scan.setFilter(prefixFilter);
		ResultScanner scanner = studentTable.getScanner(scan);
		handleResultScanner(scanner);
​
​
	} catch (IOException e) {
		e.printStackTrace();
	}
​
}
3.9、分页过滤器PageFilter
/**
 * 分页过滤器
 * 分页有两个条件
 * pageNum  第几页
 * pageSize 每页有几条
 */
@Test
public void pageFilter() throws IOException {

	int pageNum = 3;
	int pageSize = 2;


	/*
	分为两种情况判断:
	第一页
	其他页
	 */
	if (pageNum == 1){
		Scan scan = new Scan();
		//设置起始rowKey
		scan.setStartRow("".getBytes());
		//设置最大的返回结果,返回pageSize条
		scan.setMaxResultSize(pageSize);
		//分页过滤器
		PageFilter pageFilter = new PageFilter(pageSize);
		scan.setFilter(pageFilter);

		ResultScanner resultScanner = table.getScanner(scan);
		for (Result result : resultScanner) {
			byte[] row = result.getRow();
			System.out.println("数据的rowKey为" + Bytes.toString(row));
			List<Cell> cells = result.listCells();
			for (Cell cell : cells) {
				byte[] qualifier = cell.getQualifier();
				byte[] family = cell.getFamily();
				byte[] value = cell.getValue();
				//id列和age列是整型数据
				if ("f1".equals(Bytes.toString(family)) && "id".equals(Bytes.toString(qualifier)) || "age".equals(Bytes.toString(value))){
					System.out.println("列族为"+Bytes.toString(family)+"列名为"+Bytes.toString(qualifier)+"列值为"+Bytes.toInt(value));
				} else {
					System.out.println("列族为"+Bytes.toString(family)+"列名为"+Bytes.toString(qualifier)+"列值为"+Bytes.toString(value));
				}
			}
		}
	} else {
		String startRow = "";
		Scan scan = new Scan();
		/*
		第二页的起始rowKey = 第一页的结束rowKey + 1
		第三页的起始rowKey = 第二页的结束rowKey + 1
		 */
		int resultSize = (pageNum - 1) * pageSize + 1;
		scan.setMaxResultSize(resultSize);
		//设置一次性往前扫描5条,最后一个rowKey是第三页起始rowKey
		PageFilter pageFilter = new PageFilter(resultSize);
		scan.setFilter(pageFilter);
		//resultScanner里面有5条数据
		ResultScanner scanner = table.getScanner(scan);
		for (Result result : scanner) {
			//获取rowKey
			byte[] row = result.getRow();
			//最后一次循环遍历 rowKey为0005
			startRow = Bytes.toString(row);
		}
		Scan scan1 = new Scan();
		scan1.setStartRow(startRow.getBytes());
		scan1.setMaxResultSize(pageSize);

		PageFilter pageFilter1 = new PageFilter(pageSize);
		scan1.setFilter(pageFilter1);

		ResultScanner scanner1 = table.getScanner(scan1);


## 总结

面试难免让人焦虑不安。经历过的人都懂的。但是如果你提前预测面试官要问你的问题并想出得体的回答方式,就会容易很多。

此外,都说“面试造火箭,工作拧螺丝”,那对于准备面试的朋友,你只需懂一个字:刷!

给我刷刷刷刷,使劲儿刷刷刷刷刷!今天既是来谈面试的,那就必须得来整点面试真题,这不花了我整28天,做了份“Java一线大厂高岗面试题解析合集:JAVA基础-中级-高级面试+SSM框架+分布式+性能调优+微服务+并发编程+网络+设计模式+数据结构与算法等”

![image](https://img-blog.csdnimg.cn/img_convert/52319335640412cff8182e8727808cf9.webp?x-oss-process=image/format,png)

且除了单纯的刷题,也得需准备一本【JAVA进阶核心知识手册】:JVM、JAVA集合、JAVA多线程并发、JAVA基础、Spring 原理、微服务、Netty与RPC、网络、日志、Zookeeper、Kafka、RabbitMQ、Hbase、MongoDB、Cassandra、设计模式、负载均衡、数据库、一致性算法、JAVA算法、数据结构、加密算法、分布式缓存、Hadoop、Spark、Storm、YARN、机器学习、云计算,用来查漏补缺最好不过。

![image](https://img-blog.csdnimg.cn/img_convert/1f0309d77d8c58bb0e118c64927ad7fe.webp?x-oss-process=image/format,png)

> **本文已被[CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)收录**

**[需要这份系统化的资料的朋友,可以点击这里获取](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)**

数据结构与算法等”

[外链图片转存中...(img-CG2948of-1715637819641)]

且除了单纯的刷题,也得需准备一本【JAVA进阶核心知识手册】:JVM、JAVA集合、JAVA多线程并发、JAVA基础、Spring 原理、微服务、Netty与RPC、网络、日志、Zookeeper、Kafka、RabbitMQ、Hbase、MongoDB、Cassandra、设计模式、负载均衡、数据库、一致性算法、JAVA算法、数据结构、加密算法、分布式缓存、Hadoop、Spark、Storm、YARN、机器学习、云计算,用来查漏补缺最好不过。

[外链图片转存中...(img-eHoYEYla-1715637819642)]

> **本文已被[CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)收录**

**[需要这份系统化的资料的朋友,可以点击这里获取](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值