zoukankan      html  css  js  c++  java
  • Java API 实现HBase的数据添加与过滤查询

    包依赖比较麻烦,找了好久,我用的CDH5.0 现将所依赖的包的列表清单如下:

    public class EmployeeDao {

    /**
    * @param args
    */
    public static Configuration configuration;
      static {
        configuration = new Configuration();
        String filePath = "hbase-site.xml";
        Path path = new Path(filePath);
        configuration.addResource(path);
        configuration = HBaseConfiguration.create(configuration);
      }
      //使用过滤器实现查询
      public List<Employee> QueryEmployeeByName(String name) throws Exception {
        String rowKey = name;
        HTable table = new HTable(configuration, "employee".getBytes());
        Scan scan = new Scan();
        // select ..... from .. where filter
        scan.addColumn("info".getBytes(), "age".getBytes());
        scan.addColumn("info".getBytes(), "sex".getBytes());
        RowFilter filter = new RowFilter(CompareOp.EQUAL,
        new RegexStringComparator(rowKey));
        scan.setFilter(filter);
        List<Employee> list = new ArrayList<Employee>();
        ResultScanner rScanner = table.getScanner(scan);

        for (Result rs : rScanner) {
          Employee e = new Employee();
          for (KeyValue kValue : rs.list()) {
            if ("sex".equalsIgnoreCase(new String(kValue.getQualifier()))) {
              e.setSex(new String(kValue.getValue()));
            }
            if ("age".equalsIgnoreCase(new String(kValue.getQualifier()))) {
              e.setAge(Integer.parseInt((new String(kValue.getValue()))));
            }
          }
          list.add(e);
        }
        return list;
      }
      // 插入一个单元格数据
      public static void insertOneRow(String tableName, String rowkey,
        String columnFamily, String column, String value) throws Exception {
        HTable table = new HTable(configuration, tableName);
        Put put = new Put(Bytes.toBytes(rowkey));
        put.add(Bytes.toBytes(columnFamily), Bytes.toBytes(column),
        Bytes.toBytes(value));
        table.put(put);// 放入表
        table.close();// 释放资源
      }

      public static void main(String[] args) throws Exception {
        // TODO Auto-generated method stub
        EmployeeDao dao = new EmployeeDao();
        List<Employee> l = dao.QueryEmployeeByName("oftenlin");
        for (Employee e : l) {
          System.out.println("Name:oftenlin," + "Sex:" + e.getSex() + ",Age:"+ e.getAge());
        }
        //insertOneRow("employee","allen","info","scholl","shi yan mid school");
        insertOneRow("employee","gold fly","info","scholl","shi yan mid school");
        System.out.println("写入成功!");
      }

    }

    hbase-site.xml 的清单

    <?xml version="1.0" encoding="UTF-8"?>

    <!--Autogenerated by Cloudera Manager-->
    <configuration>
    <property>
    <name>hbase.rootdir</name>
    <value>hdfs://CentOS-cm:8020/hbase</value>
    </property>
    <property>
    <name>hbase.client.write.buffer</name>
    <value>2097152</value>
    </property>
    <property>
    <name>hbase.client.pause</name>
    <value>100</value>
    </property>
    <property>
    <name>hbase.client.retries.number</name>
    <value>35</value>
    </property>
    <property>
    <name>hbase.client.scanner.caching</name>
    <value>100</value>
    </property>
    <property>
    <name>hbase.client.keyvalue.maxsize</name>
    <value>10485760</value>
    </property>
    <property>
    <name>hbase.rpc.timeout</name>
    <value>60000</value>
    </property>
    <property>
    <name>hbase.snapshot.enabled</name>
    <value>true</value>
    </property>
    <property>
    <name>hbase.security.authentication</name>
    <value>simple</value>
    </property>
    <property>
    <name>zookeeper.session.timeout</name>
    <value>60000</value>
    </property>
    <property>
    <name>zookeeper.znode.parent</name>
    <value>/hbase</value>
    </property>
    <property>
    <name>zookeeper.znode.rootserver</name>
    <value>root-region-server</value>
    </property>
    <property>
    <name>hbase.zookeeper.quorum</name>
    <value>CentOS-server3,CentOS-server2,CentOS-server1</value>
    </property>
    <property>
    <name>hbase.zookeeper.property.clientPort</name>
    <value>2181</value>
    </property>
    </configuration>

  • 相关阅读:
    最实用的深度学习教程 Practical Deep Learning For Coders (Kaggle 冠军 Jeremy Howard 亲授)
    线性代数的本质与几何意义 01. 向量是什么?(3blue1brown 咪博士 图文注解版)
    【小蜜蜂老师主讲】基于STM32CubeMX的嵌入式开发基础教程
    【STM32专题教程】STM32CubeMX的安装与快速入门
    【技能大赛真题】2019年物联网国赛任务三题1-无线通信系统
    【CC2530强化实训03】定时器间隔定时实现按键长按与短按
    【CC2530强化实训04】定时器间隔定时实现按键N连击
    【CC2530强化实训02】普通延时函数实现按键的长按与短按
    【CC2530强化实训01】普通延时函数实现按键的长按与短按
    【蓝桥杯单片机12】实时时钟DS1302的基本操作
  • 原文地址:https://www.cnblogs.com/oftenlin/p/4043205.html
Copyright © 2011-2022 走看看