目录
- [(一)练习常用的HBase Shell命令](#(一)练习常用的HBase Shell命令)
- [(二)HBase 常用的Java API 及应用实例](#(二)HBase 常用的Java API 及应用实例)
-
- 1、启动hbase服务
- 2、启动eclipse
- [3、新建java project](#3、新建java project)
- [4、关闭 hbase](#4、关闭 hbase)
(一)练习常用的HBase Shell命令
1、启动HBase
先启动HDFS 再启动HBase
进入shell交互式执行环境
2、练习shell命令
data:image/s3,"s3://crabby-images/4fd45/4fd45b03b3e28316ce728b94727dc82a27214f11" alt=""
create scan list describe alter
put
get
data:image/s3,"s3://crabby-images/49335/49335af2a6e7a592d826ef08fe67ef1fa9ccc710" alt=""
delete
data:image/s3,"s3://crabby-images/fb519/fb51909089c2db5732ecf9c2cb850034b50f22ba" alt=""
data:image/s3,"s3://crabby-images/31ef8/31ef8856895dcdb6bd57807eececb6ab5887fd65" alt=""
drop
删除表前要disable它
关于NoSQL数据库中的列族和列
这些数据库允许你以非常灵活的方式存储和检索数据
data:image/s3,"s3://crabby-images/9edc7/9edc71bf877e5ab4c8bf1bf50e4b1a109f42ce46" alt=""
3、关闭hbase服务
data:image/s3,"s3://crabby-images/b7889/b7889971ec9201c900fcdcde82f124ba4f43792a" alt=""
(二)HBase 常用的Java API 及应用实例
1、启动hbase服务
data:image/s3,"s3://crabby-images/cff3b/cff3b881831edf9cd7e87956befb0a9f1a9ade6c" alt=""
2、启动eclipse
data:image/s3,"s3://crabby-images/96c0a/96c0aedf2382e8083453f07b23809f0811dab899" alt=""
3、新建java project
导入jar包
data:image/s3,"s3://crabby-images/6be55/6be55597aa6a996bab386ef6f9c754884fa7ca78" alt=""
导入/usr/local/hbase/lib中的所有jar包
再导入/usr/local/hbase/lib/client-facing-thirdparty中的所有jar 包
创建类文件
data:image/s3,"s3://crabby-images/6ea04/6ea04f06e945061ea6c310ac454100bd23b22c89" alt=""
常用Java API:
data:image/s3,"s3://crabby-images/2c349/2c3493225bebda0f8b435c61a324f73d5638fa12" alt=""
java
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.*;
import org.apache.hadoop.hbase.client.*;
import org.apache.hadoop.hbase.util.Bytes;
import java.io.IOException;
public class ExampleForHBase {
public static Configuration configuration;
public static Connection connection;
public static Admin admin;
public static void main(String[] args) throws IOException {
init();
createTable("student", new String[]{"score"});
insertData("student", "zhangsan", "score", "English", "69");
insertData("student", "zhangsan", "score", "Math", "86");
insertData("student", "zhangsan", "score", "Computer", "77");
getData("student", "zhangsan", "score", "English");
close();
}
public static void init() {
configuration = HBaseConfiguration.create();
configuration.set("hbase.rootdir", "hdfs://localhost:9000/hbase");
try {
connection = ConnectionFactory.createConnection(configuration);
admin = connection.getAdmin();
} catch (IOException e) {
e.printStackTrace();
}
}
public static void close() {
try {
if (admin != null) {
admin.close();
}
if (connection != null) {
connection.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}
public static void createTable(String myTableName, String[] colFamily) throws IOException {
TableName tableName = TableName.valueOf(myTableName);
if (admin.tableExists(tableName)) {
System.out.println("table is exists!");
} else {
TableDescriptorBuilder tableDescriptor = TableDescriptorBuilder.newBuilder(tableName);
for (String str : colFamily) {
ColumnFamilyDescriptor family = ColumnFamilyDescriptorBuilder.newBuilder(Bytes.toBytes(str)).build();
tableDescriptor.setColumnFamily(family);
}
admin.createTable(tableDescriptor.build());
}
}
public static void insertData(String tableName, String rowKey, String colFamily, String col, String val) throws IOException {
Table table = connection.getTable(TableName.valueOf(tableName));
Put put = new Put(rowKey.getBytes());
put.addColumn(Bytes.toBytes(colFamily), Bytes.toBytes(col), Bytes.toBytes(val));
table.put(put);
table.close();
}
public static void getData(String tableName, String rowKey, String colFamily, String col) throws IOException {
Table table = connection.getTable(TableName.valueOf(tableName));
Get get = new Get(rowKey.getBytes());
get.addColumn(Bytes.toBytes(colFamily), Bytes.toBytes(col));
Result result = table.get(get);
System.out.println(new String(result.getValue(Bytes.toBytes(colFamily), Bytes.toBytes(col))));
table.close();
}
}
run------>run as application
打开hbase shell
list scan