我正在尝试将年龄作为数字int Bytes.toBytes(44)插入到HTable中但值不会被持久化。 Row键也是如此。我正在使用Cloudera Quick Start VM: 这是我的代码:
package com.sohi.put;
import java.io.IOException;
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.MasterNotRunningException;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.ZooKeeperConnectionException;
import org.apache.hadoop.hbase.client.Get;
import org.apache.hadoop.hbase.client.HBaseAdmin;
import org.apache.hadoop.hbase.client.HTable;
import org.apache.hadoop.hbase.client.Put;
import org.apache.hadoop.hbase.client.Result;
import org.apache.hadoop.hbase.util.Bytes;
public class TestClass {
public static void main(String[] args) throws MasterNotRunningException, ZooKeeperConnectionException, IOException {
Configuration conf = HBaseConfiguration.create();
HBaseAdmin hBaseAdmin = new HBaseAdmin(conf);
TableName tableName = TableName.valueOf("SampleDataTable") ;
HTableDescriptor tableDescriptor = new HTableDescriptor(tableName) ;
HColumnDescriptor personalColFam = new HColumnDescriptor("personal");
HColumnDescriptor officeColFam = new HColumnDescriptor("office");
tableDescriptor.addFamily(personalColFam);
tableDescriptor.addFamily(officeColFam);
if(!hBaseAdmin.tableExists(tableName)){
hBaseAdmin.createTable(tableDescriptor);
}
HTable hTable = new HTable(conf, tableName);
byte [] row = Bytes.toBytes(121);
byte [] personalCf = Bytes.toBytes("personal");
byte [] officeCf = Bytes.toBytes("office");
byte [] qual1 = Bytes.toBytes("name");
byte [] qual2 = Bytes.toBytes("age");
byte [] qual3 = Bytes.toBytes("location");
byte [] name = Bytes.toBytes("John");
byte [] age = Bytes.toBytes(44);
byte [] loc = Bytes.toBytes("USA");
Put data = new Put(row);
data.add(personalCf, qual1, name);
data.add(personalCf, qual2, age);
data.add(officeCf, qual3, loc);
hTable.put(data);
// giving issue with integer values like age and row key
System.out.println("Done");
}
}
这是输出:
注意Key值和Age Value。
答案 0 :(得分:3)
Hue的HBase浏览器可以很好地正确显示字符串 - 但不其他数据类型。原因很简单: Hbase不知道您存储的数据类型 - 但您知道!例如,如果从HBase列读取8个字节,则可以是64位整数或浮点数或8个字符。
现在,回到你的问题:你的代码工作正常!
您看到的逗号是44
的ascii表示(请参阅http://www.ascii-code.com/)
当您在代码中从HBase读取数据时,请使用Bytes.toInt()
,您将能够正确地将其读作整数44
。
答案 1 :(得分:0)
始终建议使用字符串。但如果需要,我们也可以使用数字。为此,请尝试使用包装类--BigInteger。
byte[] val = BigInteger.valueOf(44).toByteArray();