zoukankan      html  css  js  c++  java
  • Flink实例(124):connector(二十一)hbase 读写 (二)

    package com.caimou.utils;
    
    import org.apache.hadoop.conf.Configuration;
    import org.apache.hadoop.hbase.HBaseConfiguration;
    import org.apache.hadoop.hbase.HColumnDescriptor;
    import org.apache.hadoop.hbase.HTableDescriptor;
    import org.apache.hadoop.hbase.TableName;
    import org.apache.hadoop.hbase.client.*;
    import org.apache.hadoop.hbase.util.Bytes;
    
    import java.io.IOException;
    import java.util.Map;
    import java.util.Set;
    
    
    public class HbaseUtils2 {
        private static Admin admin = null;
        private static Connection conn = null;
        static{
            // 创建hbase配置对象
            Configuration conf = HBaseConfiguration.create();
            conf.set("hbase.rootdir","hdfs://192.168.1.122:9820/hbase");
            //使用eclipse时必须添加这个,否则无法定位
            conf.set("hbase.zookeeper.quorum","192.168.1.122");
            conf.set("hbase.client.scanner.timeout.period", "600000");
            conf.set("hbase.rpc.timeout", "600000");
            try {
                conn = ConnectionFactory.createConnection(conf);
                // 得到管理程序
                admin = conn.getAdmin();
            } catch (IOException e) {
                e.printStackTrace();
            }
    
        }
    
        /**
         * 创建表
         public  static void createTable(String tabName,String famliyname) throws Exception {
         HTableDescriptor tab = new HTableDescriptor(tabName);
         // 添加列族,每个表至少有一个列族
         HColumnDescriptor colDesc = new HColumnDescriptor(famliyname);
         tab.addFamily(colDesc);
         // 创建表
         admin.createTable(tab);
         System.out.println("over");
         }
         */
    
    
        /**
         * 插入数据,create "testinfo","time"
         * create "product","info"
         * create "userinfo","info"
         */
        public static void put(String tablename, String rowkey, String famliyname, Map<String,String> datamap) throws Exception {
            Table table = conn.getTable(TableName.valueOf(tablename));
            // 将字符串转换成byte[]
            byte[] rowkeybyte = Bytes.toBytes(rowkey);
            Put put = new Put(rowkeybyte);
            if(datamap != null){
                Set<Map.Entry<String,String>> set = datamap.entrySet();
                for(Map.Entry<String,String> entry : set){
                    String key = entry.getKey();
                    Object value = entry.getValue();
                    put.addColumn(Bytes.toBytes(famliyname), Bytes.toBytes(key), Bytes.toBytes(value+""));
                }
            }
            table.put(put);
            table.close();
            System.out.println("ok");
        }
    
        /**
         * ܱ获取数据,create "testinfo","time"
         */
        public static String getdata(String tablename, String rowkey, String famliyname,String colum) throws Exception {
            Table table = conn.getTable(TableName.valueOf(tablename));
            // 将字符串转换成byte[]
            byte[] rowkeybyte = Bytes.toBytes(rowkey);
            Get get = new Get(rowkeybyte);
            Result result =table.get(get);
            byte[] resultbytes = result.getValue(famliyname.getBytes(),colum.getBytes());
            if(resultbytes == null){
                return null;
            }
    
            return new String(resultbytes);
        }
    
        /**
         * 插入数据,create "testinfo","time"
         */
        public static void putdata(String tablename, String rowkey, String famliyname,String colum,String data) throws Exception {
            Table table = conn.getTable(TableName.valueOf(tablename));
            Put put = new Put(rowkey.getBytes());
            put.addColumn(famliyname.getBytes(),colum.getBytes(),data.getBytes());
            table.put(put);
        }
    
        public static void main(String[] args) throws Exception {
    //        System.setProperty("hadoop.home.dir","E:\soft\hadoop-2.6.0-cdh5.5.1\hadoop-2.6.0-cdh5.5.1");
    //        createTable("testinfo","time");
            putdata("testinfo", "1", "time","info1","ty");
    //        Map<String,String> datamap = new HashMap<String,String>();;
    //        datamap.put("info1","ty1");
    //        datamap.put("info2","ty2");
    //        put("testinfo", "2", "time",datamap);
    
            String result = getdata("testinfo","1", "time","info1");
            System.out.println(result);
    
        }
    
    
    }
  • 相关阅读:
    字符串属于对象而非基本数据类型,为什么?
    比较字符串内容用equals,比较字符串的地址用==,为什么?
    服务器数据恢复方法,磁盘阵列崩溃怎么恢复数据
    服务器磁盘阵列数据恢复,raid5两块硬盘掉线数据恢复方法
    服务器存储共享文件夹丢失数据恢复检测报告
    SUN平台服务器光纤共享存储互斥失败如何恢复数据?
    服务器磁盘阵列存储瘫痪数据恢复成功案例
    EMC CX4-480服务器raid磁盘数据恢复案例
    服务器数据恢复方法_存储raid硬盘离线数据恢复案例
    山西某公司NetApp存储不小心删除文件数据恢复成功案例
  • 原文地址:https://www.cnblogs.com/qiu-hua/p/14352328.html
Copyright © 2011-2022 走看看