文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

phoenix怎么连接hbase

2023-07-04 15:03

关注

这篇“phoenix怎么连接hbase”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“phoenix怎么连接hbase”文章吧。

一、安装phoennix添加配置

phoenix怎么连接hbase

将phoenix-server-hbase-2.4-5.1.2.jar拷贝至hbase的的lib下

cp  phoenix-server-hbase-2.4-5.1.2.jar ../hbase/lib/

配置phoenix可以访问hbase的系统表

(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/

二、启动phoenix服务

启动hbase

../hbase/bin/start-hbase.sh

启动phoenix

python3  ../phoenix/bin/sqlline.py   server200:2181

server200:2181为zookeeper地址

phoenix怎么连接hbase

三、phoenix常用语法

 官网文档   https://phoenix.apache.org/language/index.html

(1)创建表

create table test1(id varchar primary key,a varchar,b varchar);

id主键可视为hbase的rowkey

phoenix怎么连接hbase

(2)插入数据

upsert into TEST1 values('202211160089','liuping','chenyingying');

(3) 查询数据

select * from TEST1;

phoenix怎么连接hbase

(4)视图/表映射

由于phoenix 无法直接访问hbase创建的非系统表,可以通过视图/表映射对非系统表进行查询,但视图不可修改,表映射可读可写

在hbase上创建表名为eftb列族为fm1 、fm2的表

create 'reftb','fm1','fm2'

phoenix怎么连接hbase

向表中添加数据

 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>查看数据

phoenix怎么连接hbase

phoenix怎么连接hbase

(5)添加修改数据(增改语法相同)

 upsert into "reftb"  values('010102','诸葛村夫','五十'); upsert into "reftb"  values('010101','常山赵子龙','七十');

(6)删除数据

delete from "reftb" where ID='010101';

(7)创建schema(数据库名,对用hbase是的namespace)

CREATE SCHEMA IF NOT EXISTS "my_schema";

四、java代码集成phoenix

添加依赖

implementation 'org.apache.phoenix:phoenix-client-hbase-2.4:5.1.2'

编写代码

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();        }    }        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();    }        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();        }    }}

以上就是关于“phoenix怎么连接hbase”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯