- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有一个包含 6 列的 SQL 表,“row_id”,“customer_id”,“f_name”,“l_name”,“location”,“last_update_date”。
1)我已经通过SQOOP为上面的SQL表创建了一个HBase表,下面是sqoop语法
sqoop import --connect "jdbc:sqlserver://server:port;databaseName=db" --username xxx --password xxx --table xxx --hbase-table xxx --column-family amitesh --hbase-row-key row_id,customer_id --hbase-create-table -m 1
在上面的 sqooping 中,我通过连接 2 列创建了一个 hbase 行键,它工作正常,到目前为止一切顺利。下面是 Hbase 的“扫描”输出
hbase(main):036:0> scan 'xxx'
ROW COLUMN+CELL
111_emp1 column=amitesh:f_name, timestamp=1497365606380, value=dev
111_emp1 column=amitesh:l_name, timestamp=1497365606380, value=saha
111_emp1 column=amitesh:last_update_date, timestamp=1497365606380, value=2017-06-12
111_emp1 column=amitesh:location, timestamp=1497365606380, value=hyd
112_emp1 column=amitesh:f_name, timestamp=1497365606380, value=hari
112_emp1 column=amitesh:l_name, timestamp=1497365606380, value=sri
112_emp1 column=amitesh:last_update_date, timestamp=1497365606380, value=2017-06-13
112_emp1 column=amitesh:location, timestamp=1497365606380, value=bng
2) 当我“描述 hbase_tbl”时,我发现“VERSIONS =>1”的值如下所示:
hbase(main):025:0> describe 'xxx'
Table HBASE_SQOOP is ENABLED
HBASE_SQOOP
COLUMN FAMILIES DESCRIPTION
{NAME => 'amitesh', BLOOMFILTER => 'ROW', VERSIONS => '1', IN_MEMORY => 'false', KEEP_DELETED_CELLS => 'FALSE', DATA_BLOCK_ENCODING => 'NONE', TTL => 'FOREVER', COMPRESSION
=> 'NONE', MIN_VERSIONS => '0', BLOCKCACHE => 'true', BLOCKSIZE => '65536', REPLICATION_SCOPE => '0'}
因此,为了将值更改为版本 2,我执行了以下 HBase 命令。
alter 'xxx', {NAME => 'amitesh', VERSIONS => 2}
它恰好运行成功,现在“describe”命令为 VERSION 显示的更改值是 2。
3) 现在为 HBase 行 ID 111_emp1 保留 2 个版本的 f_name 和 l_name,我更新了 row_id 111 的 SQL Server 表两次,并重新读取它,但我只能看到更新后的值,我没有看到它们的当前和过去版本,下面是“get”输出”
hbase(main):038:0> get 'xxx', '111_emp1',{COLUMN=> 'amitesh:f_name',VERSION=>2}
COLUMN CELL
amitesh:f_name timestamp=1497365606380, value=dev
1 row(s) in 0.0040 seconds
hbase(main):047:0> get 'xx', '111_emp1',{COLUMN=> 'amitesh:f_name',VERSION=>2}
COLUMN CELL
amitesh:f_name timestamp=1497365863181, value=Raj
1 row(s) in 0.0110 seconds
正如您在上面看到的 2 个“get”输出,在第一个“get”中,f_name 的值为“dev”,而对于第二个“get”,值为“raj”。但我希望看到“dev”和“raj”作为我的输出。因为按照我的“改变”命令,HBase 应该将它们放在一起,但它没有发生。
我错过了什么?
最佳答案
它是 VERSIONS => 2
。获得多个版本的正确语法是
get 'xxx', '111_emp1',{COLUMN=> 'amitesh:f_name',VERSIONS=>2}
关于sql-server - 如何在 HBase 中查看 3 版本的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44525613/
发出时Delete对于 hbase,我知道它不会立即删除数据。但是什么时候删除数据,我的意思是,物理上? 最佳答案 当您向 HBase 写入内容时,它会存储在内存存储 (RAM) 中,然后再写入磁盘。
同一行的列族属于同一个 RegionServer。 那么,这里的问题是一个 RegionServer 会在不同的机器上存储不同的列族吗? 最佳答案 不一定,但在某些时候它会。这是基本 HBase 架构
如果我想插入表格: row | fam:qualifier | timestamp | value 1 | foo:bar | 12345 | 2 1 | foo:bar | 12346 | 3 1
有时我想退出我在 HBase shell 中运行的命令,例如扫描操作通常需要太多时间。 所以我想停止运行这个命令,但我不想退出 HBase shell。 我常用的停止运行命令的方式,我使用了Ctrl+
有没有办法设置 Hbase 以便我们可以在同一个集群中创建多个数据库? 最佳答案 只是为了刷新主题:http://hbase.apache.org/book.html#namespace 5.3.1.
怎么看version的 hbase我在用? 你能下命令吗? 最佳答案 hbase version命令行界面中的命令给出了 version的 hbase正在使用中。 以下是来自 Cloudera 的两个
高级问题: HBase 是否对所有分布(因此不是实现的工件)通用的每行施加了最大大小,无论是在 方面吗?字节存储 或在 方面细胞数 ? 如果是这样: 限制是什么? 极限存在的原因是什么? 限制在哪里记
假设,假设我在数据仓库设置中有一个星型模式。 有一个非常非常长的事实表(想想几十亿到几万亿行)和几个低基数维度表(想想 100 个维度表)。每个事实表外键 指向一个维度表的主键是位图索引的。每个维度表
版本:Hadoop: 2.0.0-cdh4.3.1 HBase: 0.94.6-cdh4.3.1 我正在运行 cloudera quick start vm,这是我的小型远程 HBase Java 客
我正在尝试以完全分布式模式配置 HBase。 (使用 Ubuntu 12.04,Apache Hadoop 2.2(以伪模式运行,HBase 版本 0.98) 以下是我的 bashrc 设置: exp
我想知道如何正确配置 hbase.zookeeper.quorum 以将 zookeeper 实例指向集群模式。 最佳答案 hbase.zookeeper.quorum 属性是运行 ZooKeeper
我想知道如何正确配置 hbase.zookeeper.quorum 以将 zookeeper 实例指向集群模式。 最佳答案 hbase.zookeeper.quorum 属性是运行 ZooKeeper
我正在尝试对位于 Hbase 中的两个表进行映射连接。我的目的是在hashmap中保留小表的记录并与大表进行比较,一旦匹配,再次将记录写入hbase中的表中。我使用 Mapper 和 Reducer
我正在尝试编写一个程序来连接到 HBase。但是当我执行以下命令时HBaseConfiguration.create();我收到以下错误:. "hbase-default.xml 文件似乎是旧版本的
基于HBase documentation ,再次遵循 Google BigTable 论文的引用,据说这些行是按行键的字典顺序存储的。 很明显,当我们在 rowkey 中有一个字符串或者如果我们将一
我有一个 hbase 表,其中的行键如 row1、row2、row3 .... 和 rowN,我想要的是获取行键从 row100 到 row200 的行,如何编写查询子句或将 hbase 表设计为让查
我正在尝试创建命名空间,但出现类似下面给出的错误 hbase(main):031:0> create namespace 'Aniruddha'
我发现为以下要求建模 HBase 表有困难。 我有一个表“商店”,它存储了商店的详细信息(必胜客)。 我有一个表格“订单”,其中包含交易摘要(总交易金额等...)。 我有另一个表“Order_Item
谁能告诉我如果在不首先禁用表的情况下使用“alter”命令可能影响表结构的可能影响? 据我所知,禁用表意味着关闭与表的所有连接。如果我在不禁用表的情况下使用 alter,可能会发生什么异常情况? 我正
我无法将表从 HBase 导出到 HDFS。下面是错误跟踪。它是相当大的尺寸。还有其他方法可以导出吗? 我使用以下命令导出。我增加了 rpc 超时,但工作仍然失败。 sudo -u hdfs hbas
我是一名优秀的程序员,十分优秀!