• java操作HBase


    创建一个学生信息表,用来存储学生的姓名(姓名作为行键,且假设姓名不会重复)以及考试成绩,其中考试成绩(score)是一个列族,存储了各个科目的考试成绩。然后向student中添加数据

    1、HBase依赖

    1. org.apache.hbase
    2. hbase-server
    3. 1.4.13
    4. org.apache.hbase
    5. hbase-client
    6. 1.4.13

    2、HBase数据源

    1. package com.example.demo.config;
    2. import com.example.demo.service.ICodeService;
    3. import org.springframework.beans.factory.annotation.Autowired;
    4. import org.springframework.boot.ApplicationArguments;
    5. import org.springframework.boot.ApplicationRunner;
    6. import org.springframework.core.annotation.Order;
    7. import org.springframework.stereotype.Component;
    8. import java.util.HashMap;
    9. import java.util.List;
    10. import java.util.Map;
    11. @Component
    12. @Order(1)
    13. public class NmsHBaseSource implements ApplicationRunner {
    14. // 管理HBase的配置信息
    15. public static Configuration conf;
    16. // 管理HBase的连接
    17. public static Connection conn;
    18. // 管理HBase数据库的连接
    19. public static Admin admin;
    20. @Override
    21. public void run(ApplicationArguments args) throws Exception {
    22. conf = HBaseConfiguration.create();
    23. System.setProperty("HADOOP_USER_NAME", "hadoop");
    24. conf.set("HADOOP_USER_NAME", "hadoop");
    25. conf.set("hbase.root.dir", "hdfs://master:9000/hbase");
    26. conf.set("hbase.zookeeper.quorum", "master");//配置Zookeeper的ip地址
    27. conf.set("hbase.zookeeper.property.clientPort", "2181");//配置zookeeper的端口
    28. conn = ConnectionFactory.createConnection(conf);
    29. admin = conn.getAdmin();
    30. }
    31. /**
    32. * 关闭所有连接
    33. *
    34. * @throws IOException 可能出现的异常
    35. */
    36. public static void close() throws IOException {
    37. if (admin != null)
    38. admin.close();
    39. if (conn != null)
    40. conn.close();
    41. }
    42. /**
    43. * 创建表
    44. * @param myTableName 表名
    45. * @param colFamily 列族名的数组
    46. * @throws IOException 可能出现的异常
    47. */
    48. public static void createTable(String myTableName, String[] colFamily) throws IOException {
    49. TableName tableName = TableName.valueOf(myTableName);
    50. if (admin.tableExists(tableName)) {
    51. logger.info(myTableName + "表已经存在");
    52. } else {
    53. HTableDescriptor hTableDescriptor = new HTableDescriptor(tableName);
    54. for (String str : colFamily) {
    55. HColumnDescriptor hColumnDescriptor = new HColumnDescriptor(str);
    56. hTableDescriptor.addFamily(hColumnDescriptor);
    57. }
    58. admin.createTable(hTableDescriptor);
    59. }
    60. }
    61. /**
    62. * 添加数据
    63. * @param tableName 表名
    64. * @param rowkey 行键
    65. * @param colFamily 列族
    66. * @param col 列
    67. * @param value 值
    68. * @throws IOException 可能出现的异常
    69. */
    70. public static void insertData(String tableName,String rowkey,String colFamily,String col,String value) throws IOException {
    71. Table table = conn.getTable(TableName.valueOf(tableName));
    72. Put put = new Put(rowkey.getBytes());
    73. put.addColumn(colFamily.getBytes(),col.getBytes(),value.getBytes());
    74. table.put(put);
    75. table.close();
    76. }
    77. /**
    78. * 根据行键删除数据
    79. * @param tableName 表名
    80. * @param rowkey 行键
    81. * @throws IOException 可能出现的异常
    82. */
    83. public static void deleteData(String tableName,String rowkey) throws IOException {
    84. Table table = conn.getTable(TableName.valueOf(tableName));
    85. Delete delete = new Delete(rowkey.getBytes());
    86. table.delete(delete);
    87. table.close();
    88. }
    89. /**
    90. * 获取数据
    91. * @param tableName 表名
    92. * @param rowkey 行键
    93. * @param colFamily 列族
    94. * @param col 列
    95. * @throws IOException 可能出现的异常
    96. */
    97. public static void getData(String tableName,String rowkey,String colFamily,String col) throws IOException {
    98. Table table = conn.getTable(TableName.valueOf(tableName));
    99. Get get = new Get(rowkey.getBytes());
    100. get.addColumn(colFamily.getBytes(),col.getBytes());
    101. Result result = table.get(get);
    102. System.out.println(new String(result.getValue(colFamily.getBytes(),col.getBytes())));
    103. table.close();
    104. }
    105. public static void main(String[] args) throws IOException {
    106. init();
    107. createTable("student",new String[]{"score"});
    108. insertData("student","zhangsan","score","English","69");
    109. insertData("student","zhangsan","score","Math","86");
    110. insertData("student","zhangsan","score","Computer","77");
    111. getData("student","zhangsan","score","Computer");
    112. close();
    113. }
    114. }

    3、Hbase过滤器查询

    过滤器可以分为两种:比较过滤器和专用过滤器

    比较过滤器 

    LESS —— 小于

    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

    1. /**
    2. * ResultScanner结果解析
    3. */
    4. public void handleResultScanner(ResultScanner scanner) throws IOException {
    5. //因为ResultScanner类继承了迭代器
    6. //使用增强for循环遍历
    7. for (Result rs : scanner) {
    8. String id = Bytes.toString(rs.getRow());
    9. System.out.println("当前行的rowkey为:" + id);
    10. //继续增强for循环得到每一行中的每一个单元格(列)
    11. //获取一行中的所有单元格
    12. for (Cell cell : rs.listCells()) {
    13. //获取该单元格属于的列簇
    14. String family = Bytes.toString(CellUtil.cloneFamily(cell));
    15. //获取该单元格的列名
    16. String colName = Bytes.toString(CellUtil.cloneQualifier(cell));
    17. //获取该单元格的列值
    18. String value = Bytes.toString(CellUtil.cloneValue(cell));
    19. System.out.println(family + ":" + colName + "的值为:" + value);
    20. }
    21. String name = Bytes.toString(rs.getValue("info".getBytes(), "name".getBytes()));
    22. String age = Bytes.toString(rs.getValue("info".getBytes(), "age".getBytes()));
    23. String gender = Bytes.toString(rs.getValue("info".getBytes(), "gender".getBytes()));
    24. String clazz = Bytes.toString(rs.getValue("info".getBytes(), "clazz".getBytes()));
    25. System.out.println("学号:" + id + ",姓名:" + name + ",年龄:" + age + ",性别:" + gender + ",班级:" + clazz);
    26. }

    3.2、rowKey过滤器RowFilter

    1. /**
    2. * 行键过滤器
    3. * 通过RowFilter与BinaryComparator过滤比rowKey 1500100010小的所有值出来
    4. */
    5. @Test
    6. public void RowFilter1(){
    7. try {
    8. //获取表的实例
    9. HTableInterface students = conn.getTable("students");
    10. BinaryComparator binaryComparator = new BinaryComparator("1500100010".getBytes());
    11. //创建一个行键过滤器的对象
    12. RowFilter rowFilter = new RowFilter(CompareFilter.CompareOp.LESS, binaryComparator);
    13. Scan scan = new Scan();
    14. scan.setFilter(rowFilter);
    15. ResultScanner scanner = students.getScanner(scan);
    16. handleResultScanner(scanner);
    17. } catch (IOException e) {
    18. e.printStackTrace();
    19. }
    20. }

    3.3、列族过滤器FamilyFilter

    1. /**
    2. * 通过FamilyFilter与SubstringComparator查询列簇名包含in的所有列簇下面的数据
    3. */
    4. @Test
    5. public void FamilyFilter1(){
    6. try {
    7. //获取表的实例
    8. HTableInterface students = conn.getTable("students");
    9. //创建一个比较器对象
    10. //只要列簇名中包含了in,就把该列簇下的所有列查询出来
    11. SubstringComparator substringComparator = new SubstringComparator("in");
    12. //创建列簇过滤器
    13. FamilyFilter familyFilter = new FamilyFilter(CompareFilter.CompareOp.EQUAL, substringComparator);
    14. Scan scan = new Scan();
    15. scan.setFilter(familyFilter);
    16. //获取数据
    17. ResultScanner scanner = students.getScanner(scan);
    18. handleResultScanner(scanner);
    19. } catch (IOException e) {
    20. e.printStackTrace();
    21. }
    22. }
    23. /**
    24. * 通过FamilyFilter与 BinaryPrefixComparator 过滤出列簇以i开头的列簇下的所有数据
    25. *
    26. */
    27. @Test
    28. public void FamilyFilter2(){
    29. try {
    30. //获取表的实例
    31. HTableInterface students = conn.getTable("students");
    32. //创建前缀比较器
    33. BinaryPrefixComparator binaryPrefixComparator = new BinaryPrefixComparator("i".getBytes());
    34. //创建列簇过滤器
    35. FamilyFilter familyFilter = new FamilyFilter(CompareFilter.CompareOp.EQUAL, binaryPrefixComparator);
    36. Scan scan = new Scan();
    37. scan.setFilter(familyFilter);
    38. ResultScanner scanner = students.getScanner(scan);
    39. handleResultScanner(scanner);
    40. } catch (IOException e) {
    41. e.printStackTrace();
    42. }
    43. }

    3.4、列过滤器QualifierFilter

    1. /**
    2. * 通过QualifierFilter与SubstringComparator查询列名包含ge的列的值
    3. *
    4. */
    5. @Test
    6. public void QualifierFilter1(){
    7. try {
    8. //获取表的实例
    9. HTableInterface students = conn.getTable("students");
    10. //创建包含比较器
    11. //age
    12. //gender
    13. SubstringComparator substringComparator = new SubstringComparator("ge");
    14. //创建一个列过滤器
    15. QualifierFilter qualifierFilter = new QualifierFilter(CompareFilter.CompareOp.EQUAL, substringComparator);
    16. Scan scan = new Scan();
    17. scan.setFilter(qualifierFilter);
    18. ResultScanner scanner = students.getScanner(scan);
    19. handleResultScanner(scanner);
    20. } catch (IOException e) {
    21. e.printStackTrace();
    22. }
    23. }
    24. /**
    25. *
    26. * 通过QualifierFilter与SubstringComparator查询列名包含ge的列的值
    27. */
    28. @Test
    29. public void QualifierFilter2(){
    30. try {
    31. //获取表的实例
    32. HTableInterface students = conn.getTable("students");
    33. SubstringComparator substringComparator = new SubstringComparator("am");
    34. //创建列过滤器
    35. QualifierFilter qualifierFilter = new QualifierFilter(CompareFilter.CompareOp.EQUAL, substringComparator);
    36. Scan scan = new Scan();
    37. scan.setFilter(qualifierFilter);
    38. ResultScanner scanner = students.getScanner(scan);
    39. handleResultScanner(scanner);
    40. } catch (IOException e) {
    41. e.printStackTrace();
    42. }
    43. }

    3.5、列值过滤器ValueFilter

    1. /**
    2. * 通过ValueFilter与BinaryPrefixComparator过滤出所有的cell中值以 "张" 开头的学生
    3. */
    4. @Test
    5. public void ValueFilter1() {
    6. try {
    7. //获取表的实例
    8. HTableInterface students = conn.getTable("students");
    9. //创建前缀比较器
    10. BinaryPrefixComparator binaryPrefixComparator = new BinaryPrefixComparator("张".getBytes());
    11. //创建列值过滤器的对象
    12. ValueFilter valueFilter = new ValueFilter(CompareFilter.CompareOp.EQUAL, binaryPrefixComparator);
    13. Scan scan = new Scan();
    14. scan.setFilter(valueFilter);
    15. ResultScanner scanner = students.getScanner(scan);
    16. //因为ResultScanner类继承了迭代器
    17. //使用增强for循环遍历
    18. // for (Result rs : scanner) {
    19. // String id = Bytes.toString(rs.getRow());
    20. // System.out.println("当前行的rowkey为:" + id);
    21. // //继续增强for循环得到每一行中的每一个单元格(列)
    22. // //获取一行中的所有单元格
    23. // for (Cell cell : rs.listCells()) {
    24. // //获取该单元格属于的列簇
    25. // String family = Bytes.toString(CellUtil.cloneFamily(cell));
    26. // //获取该单元格的列名
    27. // String colName = Bytes.toString(CellUtil.cloneQualifier(cell));
    28. // //获取该单元格的列值
    29. // String value = Bytes.toString(CellUtil.cloneValue(cell));
    30. // System.out.println(family + ":" + colName + "的值为:" + value);
    31. // }
    32. // }
    33. handleResultScanner(scanner);
    34. } catch (IOException e) {
    35. e.printStackTrace();
    36. }
    37. }
    38. /**
    39. * 过滤出文科的学生,只会返回以文科开头的数据列,其他列的数据不符合条件,不会返回
    40. */
    41. @Test
    42. public void ValueFilter12(){
    43. try {
    44. //获取表的实例
    45. HTableInterface students = conn.getTable("students");
    46. //创建正则比较器
    47. RegexStringComparator regexStringComparator = new RegexStringComparator("^文科.*");
    48. //创建列值过滤器
    49. ValueFilter valueFilter = new ValueFilter(CompareFilter.CompareOp.EQUAL, regexStringComparator);
    50. Scan scan = new Scan();
    51. scan.setFilter(valueFilter);
    52. ResultScanner scanner = students.getScanner(scan);
    53. handleResultScanner(scanner);
    54. } catch (IOException e) {
    55. e.printStackTrace();
    56. }
    57. }

    3.6、单列值过滤器 SingleColumnValueFilter

    1. /**
    2. * 单列值过滤器
    3. * SingleColumnValueFilter会返回满足条件的cell所在行的所有cell的值(即会返回一行数据)
    4. *
    5. * 通过SingleColumnValueFilter与查询文科班所有学生信息
    6. */
    7. @Test
    8. public void SingleColumnValueFilter(){
    9. try {
    10. //获取表的实例
    11. HTableInterface students = conn.getTable("students");
    12. //创建一个正则比较器
    13. RegexStringComparator regexStringComparator = new RegexStringComparator("^文科.*");
    14. //创建单列值过滤器对象
    15. SingleColumnValueFilter singleColumnValueFilter = new SingleColumnValueFilter(
    16. "info".getBytes(),
    17. "clazz".getBytes(),
    18. CompareFilter.CompareOp.EQUAL,
    19. regexStringComparator
    20. );
    21. Scan scan = new Scan();
    22. scan.setFilter(singleColumnValueFilter);
    23. ResultScanner scanner = students.getScanner(scan);
    24. handleResultScanner(scanner);
    25. } catch (IOException e) {
    26. e.printStackTrace();
    27. }
    28. }

    3.7、列值排除过滤器SingleColumnValueExcludeFilter

    1. /**
    2. * 列值排除过滤器
    3. * 与SingleColumnValueFilter相反,会排除掉指定的列,其他的列全部返回
    4. *
    5. * 通过SingleColumnValueExcludeFilter与BinaryComparator查询文科一班所有学生信息,最终不返回clazz列
    6. */
    7. @Test
    8. public void SingleColumnValueExcludeFilter(){
    9. try {
    10. //获取表的实例
    11. HTableInterface students = conn.getTable("students");
    12. //创建一个二进制比较器
    13. BinaryComparator binaryComparator = new BinaryComparator("文科一班".getBytes());
    14. //创建一个列值排除过滤器
    15. SingleColumnValueExcludeFilter singleColumnValueExcludeFilter = new SingleColumnValueExcludeFilter(
    16. "info".getBytes(),
    17. "clazz".getBytes(),
    18. CompareFilter.CompareOp.EQUAL,
    19. binaryComparator
    20. );
    21. Scan scan = new Scan();
    22. scan.setFilter(singleColumnValueExcludeFilter);
    23. ResultScanner scanner = students.getScanner(scan);
    24. handleResultScanner(scanner);
    25. } catch (IOException e) {
    26. e.printStackTrace();
    27. }
    28. }

    3.8、rowKey前缀过滤器PrefixFilter

    1. /**
    2. * rowkey前缀过滤器
    3. *
    4. * 通过PrefixFilter查询以150010008开头的所有前缀的rowkey
    5. */
    6. @Test
    7. public void PrefixFilter(){
    8. try {
    9. //获取表的实例
    10. HTableInterface students = conn.getTable("students");
    11. //创建rowkey前缀过滤器
    12. PrefixFilter prefixFilter = new PrefixFilter("150010008".getBytes());
    13. Scan scan = new Scan();
    14. scan.setFilter(prefixFilter);
    15. ResultScanner scanner = students.getScanner(scan);
    16. handleResultScanner(scanner);
    17. } catch (IOException e) {
    18. e.printStackTrace();
    19. }
    20. }

    3.9、分页过滤器PageFilter

    1. /**
    2. * 分页过滤器
    3. * 分页有两个条件
    4. * pageNum 第几页
    5. * pageSize 每页有几条
    6. */
    7. @Test
    8. public void pageFilter() throws IOException {
    9. int pageNum = 3;
    10. int pageSize = 2;
    11. /*
    12. 分为两种情况判断:
    13. 第一页
    14. 其他页
    15. */
    16. if (pageNum == 1){
    17. Scan scan = new Scan();
    18. //设置起始rowKey
    19. scan.setStartRow("".getBytes());
    20. //设置最大的返回结果,返回pageSize条
    21. scan.setMaxResultSize(pageSize);
    22. //分页过滤器
    23. PageFilter pageFilter = new PageFilter(pageSize);
    24. scan.setFilter(pageFilter);
    25. ResultScanner resultScanner = table.getScanner(scan);
    26. for (Result result : resultScanner) {
    27. byte[] row = result.getRow();
    28. System.out.println("数据的rowKey为" + Bytes.toString(row));
    29. List cells = result.listCells();
    30. for (Cell cell : cells) {
    31. byte[] qualifier = cell.getQualifier();
    32. byte[] family = cell.getFamily();
    33. byte[] value = cell.getValue();
    34. //id列和age列是整型数据
    35. if ("f1".equals(Bytes.toString(family)) && "id".equals(Bytes.toString(qualifier)) || "age".equals(Bytes.toString(value))){
    36. System.out.println("列族为"+Bytes.toString(family)+"列名为"+Bytes.toString(qualifier)+"列值为"+Bytes.toInt(value));
    37. } else {
    38. System.out.println("列族为"+Bytes.toString(family)+"列名为"+Bytes.toString(qualifier)+"列值为"+Bytes.toString(value));
    39. }
    40. }
    41. }
    42. } else {
    43. String startRow = "";
    44. Scan scan = new Scan();
    45. /*
    46. 第二页的起始rowKey = 第一页的结束rowKey + 1
    47. 第三页的起始rowKey = 第二页的结束rowKey + 1
    48. */
    49. int resultSize = (pageNum - 1) * pageSize + 1;
    50. scan.setMaxResultSize(resultSize);
    51. //设置一次性往前扫描5条,最后一个rowKey是第三页起始rowKey
    52. PageFilter pageFilter = new PageFilter(resultSize);
    53. scan.setFilter(pageFilter);
    54. //resultScanner里面有5条数据
    55. ResultScanner scanner = table.getScanner(scan);
    56. for (Result result : scanner) {
    57. //获取rowKey
    58. byte[] row = result.getRow();
    59. //最后一次循环遍历 rowKey为0005
    60. startRow = Bytes.toString(row);
    61. }
    62. Scan scan1 = new Scan();
    63. scan1.setStartRow(startRow.getBytes());
    64. scan1.setMaxResultSize(pageSize);
    65. PageFilter pageFilter1 = new PageFilter(pageSize);
    66. scan1.setFilter(pageFilter1);
    67. ResultScanner scanner1 = table.getScanner(scan1);
    68. for (Result result : scanner1) {
    69. byte[] row = result.getRow();
    70. System.out.println("数据的rowKey为" + Bytes.toString(row));
    71. List cells = result.listCells();
    72. for (Cell cell : cells) {
    73. // byte[] qualifier = cell.getQualifier();
    74. // byte[] family = cell.getFamily();
    75. // byte[] value = cell.getValue();
    76. String family = Bytes.toString(CellUtil.cloneFamily(cell));
    77. //获取该单元格的列名
    78. String colName = Bytes.toString(CellUtil.cloneQualifier(cell));
    79. //获取该单元格的列值
    80. String value = Bytes.toString(CellUtil.cloneValue(cell));
    81. //id列和age列是整型数据
    82. if ("f1".equals(Bytes.toString(family)) && "id".equals(Bytes.toString(qualifier)) || "age".equals(Bytes.toString(value))){
    83. System.out.println("列族为"+Bytes.toString(family)+"列名为"+Bytes.toString(qualifier)+"列值为"+Bytes.toInt(value));
    84. } else {
    85. System.out.println("列族为"+Bytes.toString(family)+"列名为"+Bytes.toString(qualifier)+"列值为"+Bytes.toString(value));
    86. }
    87. }
    88. }
    89. }
    90. }

    3.10、多过滤器综合查询FilterList

    1. /**
    2. * 通过运用4种比较器过滤出姓于,年纪大于23岁,性别为女,且是理科的学生。
    3. *
    4. * 正则比较器 RegexStringComparator
    5. * 包含比较器 SubstringComparator
    6. * 二进制前缀比较器 BinaryPrefixComparator
    7. * 二进制比较器 BinaryComparator
    8. *
    9. */
    10. @Test
    11. public void FilterData1(){
    12. try {
    13. //获取表的实例
    14. HTableInterface students = conn.getTable("students");
    15. /**
    16. * 第一个过滤器,过滤出是理科开头的班级
    17. */
    18. RegexStringComparator regexStringComparator = new RegexStringComparator("^理科.*");
    19. //单列值过滤器
    20. SingleColumnValueFilter singleColumnValueFilter = new SingleColumnValueFilter("info".getBytes(), "clazz".getBytes(),
    21. CompareFilter.CompareOp.EQUAL, regexStringComparator);
    22. /**
    23. * 第二个过滤器,过滤出性别是女生的
    24. */
    25. SubstringComparator substringComparator = new SubstringComparator("女");
    26. SingleColumnValueFilter singleColumnValueFilter1 = new SingleColumnValueFilter("info".getBytes(), "gender".getBytes(),
    27. CompareFilter.CompareOp.EQUAL, substringComparator);
    28. /**
    29. * 第三个过滤器,过滤出年龄大于23岁的
    30. */
    31. BinaryComparator binaryComparator = new BinaryComparator("20".getBytes());
    32. SingleColumnValueFilter singleColumnValueFilter2 = new SingleColumnValueFilter("info".getBytes(), "age".getBytes(),
    33. CompareFilter.CompareOp.GREATER, binaryComparator);
    34. /**
    35. * 第四个过滤器,过滤出姓于的学生
    36. */
    37. BinaryPrefixComparator binaryPrefixComparator = new BinaryPrefixComparator("于".getBytes());
    38. SingleColumnValueFilter singleColumnValueFilter3 = new SingleColumnValueFilter("info".getBytes(), "name".getBytes(),
    39. CompareFilter.CompareOp.EQUAL, binaryPrefixComparator);
    40. Scan scan = new Scan();
    41. //要想实现多个需求同时过滤,就需要创建多个过滤器,添加到一个过滤器列表中
    42. //然后将过滤器列表传给扫描器scan
    43. FilterList filterList = new FilterList();
    44. filterList.addFilter(singleColumnValueFilter);
    45. filterList.addFilter(singleColumnValueFilter1);
    46. filterList.addFilter(singleColumnValueFilter2);
    47. filterList.addFilter(singleColumnValueFilter3);
    48. scan.setFilter(filterList);
    49. ResultScanner scanner = students.getScanner(scan);
    50. handleResultScanner(scanner);
    51. } catch (IOException e) {
    52. e.printStackTrace();
    53. }
    54. }
    55. /**
    56. * 过滤出学号是以15001001开头的文科学生
    57. */
    58. @Test
    59. public void filterData2(){
    60. try {
    61. //获取表的实例
    62. HTableInterface students = conn.getTable("students");
    63. /**
    64. * 创建第一个过滤器,过滤是以15001001开头的rowkey
    65. */
    66. BinaryPrefixComparator binaryPrefixComparator = new BinaryPrefixComparator("15001001".getBytes());
    67. //创建行键过滤器
    68. RowFilter rowFilter = new RowFilter(CompareFilter.CompareOp.EQUAL, binaryPrefixComparator);
    69. /**
    70. * 创建第二个过滤器,过滤出文科的学生
    71. */
    72. RegexStringComparator regexStringComparator = new RegexStringComparator("^文科.*");
    73. SingleColumnValueFilter singleColumnValueFilter = new SingleColumnValueFilter("info".getBytes(), "clazz".getBytes(),
    74. CompareFilter.CompareOp.EQUAL,
    75. regexStringComparator);
    76. FilterList filterList = new FilterList();
    77. filterList.addFilter(rowFilter);
    78. filterList.addFilter(singleColumnValueFilter);
    79. Scan scan = new Scan();
    80. scan.setFilter(filterList);
    81. ResultScanner scanner = students.getScanner(scan);
    82. handleResultScanner(scanner);
    83. } catch (IOException e) {
    84. e.printStackTrace();
    85. }
    86. }

  • 相关阅读:
    基本数据类型和运算符(java)
    安路远程调试使用chipwatcher报错
    QT入门10个小demo——连接MySql实现登录模块
    科普文:一文搞懂jvm原理(三)执行引擎
    优雅的接口防刷处理方案
    关于unordered_map中元素的插入顺序与遍历顺序问题
    计网学习笔记一 Networking && Internet
    STL——查找算法及实例
    并发编程(多线程)-可见性问题
    VMware ESXi 8.0 SLIC 2.6 & macOS Unlocker (Oct 2022 GA)
  • 原文地址:https://blog.csdn.net/qq_41482600/article/details/136655894