小记--------hbase数据库java API 常用方法及案例
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 常用方法及案例相关推荐
- Hbase高手之路 -- 第五章 -- HBase的Java API编程
Hbase高手之路 – 第五章 – HBase的Java API编程 一. 需求与数据集 某自来水公司,需要存储大量的缴费明细数据,以下截取了缴费明细的一部分内容: 因为缴费明细的数据记录非常庞大,该 ...
- 5 hbase-shell + hbase的java api
本博文的主要内容有 .HBase的单机模式(1节点)安装 .HBase的单机模式(1节点)的启动 .HBase的伪分布模式(1节点)安装 .HBase的伪分布模式(1节点)的启动 .HBase ...
- HBase 基本Java API
数据库:HBaseConfiguration HBaseAdmin 表:HTable HTableDescriptor 列族:HColumnDescriptor 行列操作:Put Get Sc ...
- hbase 单机 java api,HBase学习(一)hbase安装(单机模式)和javaapi客户端访问hbase例子...
平时习惯了window下开发,而Hbase只能在linux环境下运行,所以决定把hbase安装一台虚拟机上,在windows下运行eclipse连接虚拟机里的hbase 因为对linux命令了解不多, ...
- HBase基本操作-java api
上次将了HBase搭建完成后,一些Shell的使用,现在我们将了解一下HBase的代码控制,我使用的是java8以及hbase2.1.1版本 首先你的集群已经是搭建完成了,然后这次我使用的是IDEA, ...
- 简单hbase java,Hbase 简单java API 操作
package utils; import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.hbase.TableName ...
- HBASE的java api简介
一:创建表 //获取配置 Configuration conf = new Configuration(); //填写配置信息 conf.set("hbase.zookeeper.quoru ...
- HBase应用笔记:通过Java Api与HBase交互(转自 Taobao QA Team)
http://blog.sina.com.cn/s/blog_66474b1601017hvx.html http://www.cnblogs.com/eprsoft/archive/2012/10/ ...
- Elasticsearch——使用Java API实现ES中的索引、映射、文档操作
文章目录: 1.开篇 2.案例详解 2.1 创建ES客户端:完成与ES服务端的连接 2.2 创建索引 2.3 查看索引 2.4 删除索引 2.5 创建文档 2.6 修改文档 2.7 查看文档 2.8 ...
最新文章
- QMetaObject::connectSlotsByName: No matching signal for问题的解决方法
- oracle中创建函数行变列,oracle decode 函数实现行转列
- 本题中的变量(不包括变量ID)进行z-score标准化
- MongoDB 和 Python 不通用的操作
- redis服务器学习一
- 网站跳出率的相关要点介绍
- 使用 C# (.NET Core) 实现模板方法模式 (Template Method Pattern)
- 前端学习(1641):前端系列实战课程之js的组成部分
- mysql 101_MySQL 调优/优化的 101 个建议!
- Entity Framework 学习总结之三:架构组成介绍
- js中DOM, DOCUMENT, BOM, WINDOW 区别
- 使用Python教你秒搭本地服务器
- Java注释以及快捷键
- 开始使用Mac OS X
- 三年级计算机课标,三年级信息技术教案上册
- [转载】中移物联网NB模组注册指令生成小工具-M5310/M5310_A
- 前端开发公众号的调试
- docker 创建redis容器
- Java终结者和捷安特pp_终结者致命的弱点-我会怎么对付终结者
- 一道透解promise与宏/微任务的面试题
热门文章
- 利用朴素贝叶斯分类算法对搜狐新闻进行分类(python)
- java实现,如何在当前时间往后推三十天
- matlab 编程小球经历路程(s)以及第几次反弹高度(L)
- matlab研究,基于MATLAB的实时数据采集与分析研究
- JavaScript 银行登录存取钱【案例】
- flink1.12.0学习笔记第2篇-流批一体API
- python统计word页码_python 实现 Word Count
- 读研的那些事儿(三)
- 西京学院学位计算机题库和答案,西京学院 学位英语 普通英语 精彩试题整理.doc...
- 链路聚合,链路聚合是什么意思