HBaseAdmin类:管理hbase数据库的表信息,‘创建表、删除表、列出表选项、使表有效/无效、添加或删除列簇’;

  

  Eg:

  //使用工厂模式创建connection

  val conn: Connection= ConnectionFactory.createConnection(config)

  //实例化hbase的管理者实例

  val admin: Admin= conn.getAdmin

  //删除表

  admin.deleteTable(TableName.valueOf("t1"))

  HbaseConfiguration类继承自Configuration类:将hbase配置文件添加到配置中

  

  //配置hbase资源配置

  val config: Configuration=HBaseConfiguration.create()

  config.set("hbase.zookeeper.quorum" , "df1:2181,df2:2181,df3:2181")

  config.set("hbase.master" , "df1:60000")

  config.set("hbase.zookeeper.property.clientPort" , "2181")

  Table类:用于和hbase表直接通信;

  在0.94版本之后就不推荐使用

  val HTable=new HTable(conf, Bytes.toBytes(tablename))

  而是使用

  val table=Connection.getTable(TableName.valueOf(“driver_info”))

  

  Eg:

  def tableoperation(): Unit = {

  //获取表的实例

  val tab=conn.getTable(TableName.valueOf("citycode"))

  //查看rowkey的值为99手否在表中存在

  val q: Boolean=tab.exists(new Get(Bytes.toBytes("99")))

  //检查row/family/qualifier是否与数据库匹配。如果是,则提交put操作到服务端

  val sss=tab.checkAndPut(Bytes.toBytes("99") , Bytes.toBytes("MM") , Bytes.toBytes("citycode") , Bytes.toBytes("3213") , put())

  //释放所有资源或挂起内部缓冲区的更新

  tab.close()

  // 获取rowkey的列族MM的列名id的value值

  val get=new Get(Bytes.toBytes("rowKey"))

  val result: Result =tab.get(get)

  val bytes =result.getValue(Bytes.toBytes("MM"),Bytes.toBytes("id"))

  println(Bytes.toString(bytes))

  //获取MM的scanner实例

  val scanner:ResultScanner=tab.getScanner(Bytes.toBytes("MM"))

  // 获取该表的HTableDescriptor实例

  val tableDescriptor: HTableDescriptor= tab.getTableDescriptor()

  //将put实例中的数据放入表中

  tab.put(put())

  }

  HTableDescriptor类:hbase表的详细信息

  

  Eg:

  //创建HTableDescriptor table表描述

  val tabledescriptor=new HTableDescriptor(TableName.valueOf("order_info"))

  //给表添加列簇

  tabledescriptor.addFamily(new HColumnDescriptor("CC"))

  //删除CC 列簇

  tabledescriptor.removeFamily(Bytes.toBytes("CC"))

  //获取表名

  val tablename= tabledescriptor.getTableName

  HColumnDescriptor类:列簇描述

  

  Eg:

  val columndescriptor =new HColumnDescriptor(Bytes.toBytes("MM"))

  val columnName = columndescriptor.getName()

  val c =columndescriptor.getValue("id")

  Put类:对单行执行put操作

  

  Eg:

  val put =new Put(Bytes.toBytes("rowkey"))

  //添加列id和值123 到MM列簇

  put.addColumn(Bytes.toBytes("MM"),Bytes.toBytes("id"),Bytes.toBytes("123"))

  val rowname = put.getRow()

  val time = put.getTimeStamp()

  val s:Boolean =put.isEmpty()

  Get类:用于对单行执行get操作

  

  Scan类:用于执行扫描操作;通过不同的构造方法扫描整张表、整个列簇、整个列、一段时间戳范围内的数据

  Eg:

  val table: Table =conn.getTable(TableName.valueOf("driver_info"))

  // scan 全表

  val scan=new Scan()

  //给scan加条件获取列簇MM中的列id

  scan.addColumn(Bytes.toBytes("MM"),Bytes.toBytes("id"))

  //获取列簇MM中所有的列

  scan.addFamily(Bytes.toBytes("MM"))

  // 获取时间戳在11111-22222之间的所有数据

  scan.setTimeRange(11111,22222)

  //scan从rowkey20190101 开始到结束

  val scan1=new Scan(Bytes.toBytes("20190101"))

  //scan从rowkey20190101开始到20200101结束

  val scan2=new Scan(Bytes.toBytes("20190101"),Bytes.toBytes("20200101"))

  //通过扫描器scan控制查询到的结果

  val rs: ResultScanner=table.getScanner(scan)

  Filter配合Scan工作

  //1.实例化filter RowFilter 按行过滤 行键小于等于20190101的所有数据

  //CompareFilter.CompareOp.LESS_OR_EQUAL 比较符 LESS_OR_EQUAL 小于等于、LESS小于、EQUAL等于、NOT_EQUAL不等于、GREATER_OR_EQUAL大于等于、GREATER大于、NO_OP 无操作

  val rowfilter=new RowFilter(CompareFilter.CompareOp.LESS_OR_EQUAL,new BinaryComparator(Bytes.toBytes( "20190101")))

  //实例化scan

  val scan4=new Scan()

  //添加 行过滤器

  scan.setFilter(rowfilter)

  // 获取数据

  val scanner: ResultScanner= table.getScanner(scan4)

  import scala.collection.JavaConverters._

  //遍历数据

  for(sca

  println(sca)

  }

  //2. 实例化 QualifierFilter 扫描出所有的列名为id 的列数据

  val liefilter=new QualifierFilter(CompareFilter.CompareOp.EQUAL,new BinaryComparator(Bytes.toBytes("id")))

  //3. 实例化FamilyFilter 扫描出所有的列簇为'MM'的列簇数据

  val familyfilter=new FamilyFilter(CompareFilter.CompareOp.EQUAL,new BinaryComparator(Bytes.toBytes("MM")))

  // 4.扫描出行键前缀为2019 的所有行数据

  val prefilter=new PrefixFilter(Bytes.toBytes("2019"))

  // 5.只返回每行数据的 行键-列簇-列;不返回值。

  // 所以适用于 不需要值的应用场景, 减少值的传递

  val keyonlyfilter=new KeyOnlyFilter()

  // 6.扫描出所有列的值为100 的 列

  val valuefilter=new ValueFilter(CompareFilter.CompareOp.EQUAL, new BinaryComparator(Bytes.toBytes("100")))

小记--------hbase数据库java API 常用方法及案例相关推荐

  1. Hbase高手之路 -- 第五章 -- HBase的Java API编程

    Hbase高手之路 – 第五章 – HBase的Java API编程 一. 需求与数据集 某自来水公司,需要存储大量的缴费明细数据,以下截取了缴费明细的一部分内容: 因为缴费明细的数据记录非常庞大,该 ...

  2. 5 hbase-shell + hbase的java api

    本博文的主要内容有 .HBase的单机模式(1节点)安装 .HBase的单机模式(1节点)的启动 .HBase的伪分布模式(1节点)安装  .HBase的伪分布模式(1节点)的启动    .HBase ...

  3. HBase 基本Java API

    数据库:HBaseConfiguration  HBaseAdmin 表:HTable  HTableDescriptor 列族:HColumnDescriptor 行列操作:Put  Get  Sc ...

  4. hbase 单机 java api,HBase学习(一)hbase安装(单机模式)和javaapi客户端访问hbase例子...

    平时习惯了window下开发,而Hbase只能在linux环境下运行,所以决定把hbase安装一台虚拟机上,在windows下运行eclipse连接虚拟机里的hbase 因为对linux命令了解不多, ...

  5. HBase基本操作-java api

    上次将了HBase搭建完成后,一些Shell的使用,现在我们将了解一下HBase的代码控制,我使用的是java8以及hbase2.1.1版本 首先你的集群已经是搭建完成了,然后这次我使用的是IDEA, ...

  6. 简单hbase java,Hbase 简单java API 操作

    package utils; import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.hbase.TableName ...

  7. HBASE的java api简介

    一:创建表 //获取配置 Configuration conf = new Configuration(); //填写配置信息 conf.set("hbase.zookeeper.quoru ...

  8. HBase应用笔记:通过Java Api与HBase交互(转自 Taobao QA Team)

    http://blog.sina.com.cn/s/blog_66474b1601017hvx.html http://www.cnblogs.com/eprsoft/archive/2012/10/ ...

  9. Elasticsearch——使用Java API实现ES中的索引、映射、文档操作

    文章目录: 1.开篇 2.案例详解 2.1 创建ES客户端:完成与ES服务端的连接 2.2 创建索引 2.3 查看索引 2.4 删除索引 2.5 创建文档 2.6 修改文档 2.7 查看文档 2.8 ...

最新文章

  1. QMetaObject::connectSlotsByName: No matching signal for问题的解决方法
  2. oracle中创建函数行变列,oracle decode 函数实现行转列
  3. 本题中的变量(不包括变量ID)进行z-score标准化
  4. MongoDB 和 Python 不通用的操作
  5. redis服务器学习一
  6. 网站跳出率的相关要点介绍
  7. 使用 C# (.NET Core) 实现模板方法模式 (Template Method Pattern)
  8. 前端学习(1641):前端系列实战课程之js的组成部分
  9. mysql 101_MySQL 调优/优化的 101 个建议!
  10. Entity Framework 学习总结之三:架构组成介绍
  11. js中DOM, DOCUMENT, BOM, WINDOW 区别
  12. 使用Python教你秒搭本地服务器
  13. Java注释以及快捷键
  14. 开始使用Mac OS X
  15. 三年级计算机课标,三年级信息技术教案上册
  16. [转载】中移物联网NB模组注册指令生成小工具-M5310/M5310_A
  17. 前端开发公众号的调试
  18. docker 创建redis容器
  19. Java终结者和捷安特pp_终结者致命的弱点-我会怎么对付终结者
  20. 一道透解promise与宏/微任务的面试题

热门文章

  1. 利用朴素贝叶斯分类算法对搜狐新闻进行分类(python)
  2. java实现,如何在当前时间往后推三十天
  3. matlab 编程小球经历路程(s)以及第几次反弹高度(L)
  4. matlab研究,基于MATLAB的实时数据采集与分析研究
  5. JavaScript 银行登录存取钱【案例】
  6. flink1.12.0学习笔记第2篇-流批一体API
  7. python统计word页码_python 实现 Word Count
  8. 读研的那些事儿(三)
  9. 西京学院学位计算机题库和答案,西京学院 学位英语 普通英语 精彩试题整理.doc...
  10. 链路聚合,链路聚合是什么意思