大數(shù)據(jù)開(kāi)發(fā)phoenix連接hbase流程詳解
一、安裝phoennix添加配置

1、將phoenix-server-hbase-2.4-5.1.2.jar拷貝至hbase的的lib下
cp phoenix-server-hbase-2.4-5.1.2.jar ../hbase/lib/
2、配置phoenix可以訪問(wèn)hbase的系統(tǒng)表
(1)將以下配置添加至hbase-site.xml中
<property>
<name>phoenix.schema.isNamespaceMappingEnabled</name>
<value>true</value>
</property>
<property>
<name>phoenix.schema.mapSystemTablesToNamespace</name>
<value>true</value>
</property>(2)將hbase-stie.xml拷貝到phoenix/bin目錄下
cp ../hbase/conf/hbase-site.xml ../phoenix/bin/
二、啟動(dòng)phoenix服務(wù)
1、啟動(dòng)hbase
../hbase/bin/start-hbase.sh
2、啟動(dòng)phoenix
python3 ../phoenix/bin/sqlline.py server200:2181
server200:2181為zookeeper地址

三、phoenix常用語(yǔ)法
官網(wǎng)文檔 https://phoenix.apache.org/language/index.html
(1)創(chuàng)建表
create table test1(id varchar primary key,a varchar,b varchar);
id主鍵可視為hbase的rowkey
?
(2)插入數(shù)據(jù)
upsert into TEST1 values('202211160089','liuping','chenyingying');(3) 查詢(xún)數(shù)據(jù)
select * from TEST1;

(4)視圖/表映射
由于phoenix 無(wú)法直接訪問(wèn)hbase創(chuàng)建的非系統(tǒng)表,可以通過(guò)視圖/表映射對(duì)非系統(tǒng)表進(jìn)行查詢(xún),但視圖不可修改,表映射可讀可寫(xiě)
在hbase上創(chuàng)建表名為eftb列族為fm1 、fm2的表
create 'reftb','fm1','fm2'

向表中添加數(shù)據(jù)
put 'reftb','010101','fm1:name','zhangsan' put 'reftb','010101','fm2:age','九千歲'
<1>視圖映射
create view "reftb"(id varchar primary key,"fm1"."name" varchar,"fm2"."age" varchar);
<2>表映射
create table "reftb"(id varchar primary key,"fm1"."name" varchar,"fm2"."age" varchar);
<3>查看數(shù)據(jù)


(5)添加修改數(shù)據(jù)(增改語(yǔ)法相同)
upsert into "reftb" values('010102','諸葛村夫','五十');
upsert into "reftb" values('010101','常山趙子龍','七十');(6)刪除數(shù)據(jù)
delete from "reftb" where ID='010101';
(7)創(chuàng)建schema(數(shù)據(jù)庫(kù)名,對(duì)用hbase是的namespace)
CREATE SCHEMA IF NOT EXISTS "my_schema";
四、java代碼集成phoenix
1、添加依賴(lài)
implementation 'org.apache.phoenix:phoenix-client-hbase-2.4:5.1.2'
2、編寫(xiě)代碼
public class PhoenixJdbcUtils {
private final static Logger LOGGER = LoggerFactory.getLogger(PhoenixJdbcUtils.class);
private static Connection connection;
static {
Properties properties =new Properties();
PhoenixDriver instance = PhoenixDriver.INSTANCE;
try {
connection = instance.connect("jdbc:phoenix:server200:2181", properties);
///connection = DriverManager.getConnection("jdbc:phoenix:server200:2181", properties);
} catch (SQLException e) {
e.printStackTrace();
}
}
/**
* 插入數(shù)據(jù)
* @throws SQLException
*/
public static void testUpsertData() throws SQLException {
PreparedStatement psUpsert = connection.prepareStatement( " upsert into \"reftb\" values('168936','劉備','63')");
boolean addData = psUpsert.execute();
LOGGER.info("addData---------"+addData);
connection.commit();
}
/**
* 查詢(xún)數(shù)據(jù)
* @throws SQLException
*/
public static void testQueryData() throws SQLException {
PreparedStatement psQuery = connection.prepareStatement(" select * from \"reftb\" ");
ResultSet resultSet = psQuery.executeQuery();
while (resultSet.next()) {
LOGGER.info("id--{}",resultSet.getString(1));
LOGGER.info("name--{}",resultSet.getString(2));
LOGGER.info("age--{}",resultSet.getString(3));
}
}
public static void main(String[] args) {
try {
testQueryData();
testUpsertData();
} catch (Exception e) {
e.printStackTrace();
}
}
}到此這篇關(guān)于大數(shù)據(jù)開(kāi)發(fā)phoenix連接hbase流程詳解的文章就介紹到這了,更多相關(guān)phoenix連接hbase內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
pentaho工具將數(shù)據(jù)庫(kù)數(shù)據(jù)導(dǎo)入導(dǎo)出為Excel圖文步驟
本篇博客講述的是如何使用pentaho工具快速的將數(shù)據(jù)庫(kù)數(shù)據(jù)導(dǎo)出為Excel文件,以及如何將Excel文件數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫(kù),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2022-03-03
數(shù)據(jù)庫(kù)中的左連接(left join)和右連接(right join)區(qū)別
關(guān)于左連接和右連接總結(jié)性的一句話,左連接 where只影向右表,右連接where只影響左表2012-06-06
解決navicat遠(yuǎn)程連接mysql報(bào)錯(cuò)10038的問(wèn)題
這篇文章主要介紹了解決navicat遠(yuǎn)程連接mysql報(bào)錯(cuò)10038的問(wèn)題,本文分步驟通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11
使用 Navicat 創(chuàng)建數(shù)據(jù)庫(kù)并用JDBC連接的操作方法
這篇文章主要介紹了使用 Navicat 創(chuàng)建數(shù)據(jù)庫(kù)并用JDBC連接的操作方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11
Navicat?Premium?15?工具自動(dòng)被殺毒防護(hù)軟件刪除的兩種解決方法
這篇文章主要介紹了Navicat?Premium?15?工具自動(dòng)被殺毒防護(hù)軟件刪除的兩種解決方法,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-02-02
動(dòng)態(tài)SQL在梧桐數(shù)據(jù)庫(kù)的使用方法及適應(yīng)場(chǎng)景
這篇文章主要介紹了動(dòng)態(tài)SQL在梧桐數(shù)據(jù)庫(kù)的使用方法及適應(yīng)場(chǎng)景,通過(guò)簡(jiǎn)單的例子展示了如何在梧桐數(shù)據(jù)庫(kù)中使用動(dòng)態(tài)SQL,動(dòng)態(tài)SQL可以靈活處理不同量的輸入?yún)?shù),提升查詢(xún)效率,但也會(huì)增加代碼調(diào)試的難度,適用場(chǎng)景包括處理不確定的參數(shù)、通過(guò)輸入生成其他參數(shù)以及在for循環(huán)中使用2024-11-11
IntellJ Idea 2020版添加sqlite數(shù)據(jù)庫(kù)的方法
這篇文章主要介紹了IntellJ Idea 2020版添加sqlite數(shù)據(jù)庫(kù)的方法,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11
海量數(shù)據(jù)庫(kù)的查詢(xún)優(yōu)化及分頁(yè)算法方案集合1/2
海量數(shù)據(jù)庫(kù)的查詢(xún)優(yōu)化及分頁(yè)算法方案集合1/2...2007-03-03

