Apache Phoenix的Array类型
Apache Phoenix支持JDBC ARRAY类型,任何原生的数据类型就可以在ARRAY中使用。下面我介绍一下在创建的表中使用ARRAY类型。
先看一下创建表的SQL语句:
CREATE TABLE regions (
region_name VARCHAR,
zips VARCHAR ARRAY[10],
CONSTRAINT pk PRIMARY KEY (region_name)
);
或者创建ARRAY类型时不指定大小,如下:
CREATE TABLE regions (
region_name VARCHAR,
zips VARCHAR[],
CONSTRAINT pk PRIMARY KEY (region_name)
);
接着我们插入一些数据:
UPSERT INTO regions(region_name,zips) VALUES('SFBay Area',ARRAY['94115','94030','94125']);
UPSERT INTO regions(region_name,zips) VALUES('PalaArea',ARRAY['94030','98030','95125']);
或者通过JDBC编程方式插入数据:
package com.pingan.phoenix;
import Java.sql.Array;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class ConnPhoenixOp {
public static void main(String[] args) throws SQLException {
Statement stmt = null;
ResultSet rset = null;
PreparedStatement stmt2 = null;
Connection conn = DriverManager.getConnection("jdbc:phoenix:10.20.18.24:2181:/hbase114");
stmt = conn.createStatement();
stmt.executeUpdate("DROPTABLE IF EXISTS regions");
stmt.executeUpdate("CREATETABLE regions (region_name VARCHAR, zips VARCHAR[], CONSTRAINT pk PRIMARY KEY(region_name))");
stmt.executeUpdate("UPSERTINTO regions(region_name,zips) VALUES('SF Bay Area', ARRAY['94115','94030','94125'])");
conn.commit();
stmt2 = conn.prepareStatement("UPSERT INTO regions VALUES(?,?)");
stmt2.setString(1,"Pala Area");
String[] zips = new String[] {"94030","98030","95125"};
Array array = conn.createArrayOf("VARCHAR", zips);
stmt2.setArray(2, array);
stmt2.executeUpdate();
conn.commit();
stmt2 = conn.prepareStatement("SELECT region_name FROM regions WHERE zips[1] = '94030' OR zips[2] ='94030' OR zips[3] = '94030'");
rset = stmt2.executeQuery();
while (rset.next()) {
System.out.println(rset.getString("region_name"));
}
stmt2.close();
stmt.close();
conn.close();
}
}
我们查看一下regions的全部数据:
过滤部分数据:
查询Array的部分内容:
SELECT zips[1] FROM regions WHERE region_name = 'SF Bay Area';
结果:
+---------------------------------+
| ARRAY_ELEM(ZIPS, 1) |
+----------------------------------+
| 94115 |
+----------------------------------+
SELECT region_name FROM regions WHERE zips[1] = '94030' OR zips[2] = '94030' OR zips[3] = '94030';
结果为:
+-------------------------+
| REGION_NAME |
+-------------------------+
| Pala Area |
| SF Bay Area |
+-------------------------+
查看Array中元素个数:
SELECT ARRAY_LENGTH(zips) FROM regions;
结果为:
+---------------------------------+
| ARRAY_LENGTH(ZIPS) |
+----------------------------------+
| 3 |
| 3 |
+----------------------------------+
在Array中搜索相关内容,可以使用ANY和ALL内置函数:
SELECT region_name FROM regions WHERE '94030' = ANY(zips);
返回:
+--------------------------+
| REGION_NAME |
+--------------------------+
| Pala Area |
| SF Bay Area |
+-------------------------+
SELECT region_name FROM regions WHERE '94030' = ALL(zips);
没有结果。
上面使用ANY函数的SQL等价于:
SELECT region_name FROM regions WHERE zips[1] = '94030' OR zips[2] = '94030' OR zips[3] = '94030';
使用ALL函数的SQL等价于:
SELECT region_name FROM regions WHERE zips[1] = '94030' AND zips[2] = '94030' AND zips[3] = '94030';
Apache Phoenix的Array类型的更多相关文章
- phoenix 报错:type org.apache.phoenix.schema.types.PhoenixArray is not supported
今天用phoenix报如下错误: 主要原因: hbase的表中某字段类型是array,phoenix目前不支持此类型 解决方法: 复制替换phoenix包的cursor文件 # Copyright 2 ...
- Apache Phoenix系列 | 从入门到精通(转载)
原文地址:https://cloud.tencent.com/developer/article/1498057 来源: 云栖社区 作者: 瑾谦 By 大数据技术与架构 文章简介:Phoenix是一个 ...
- Apache Phoenix基本操作-1
本篇我们将介绍phoenix的一些基本操作. 1. 如何使用Phoenix输出Hello World? 1.1 使用sqlline终端命令 sqlline.py SZB-L0023780:2181:/ ...
- Apache Phoenix基本操作-2
1. 如何映射一个Phoenix的表到一个Hbase的表? 你可以通过Create table/create view DDL语句在一个已经存在的hbase表上创建一个Phoenix表或者视图.对于C ...
- JS高程5.引用类型(2)Array类型
Array类型: ECMAScript数组的每一项可以保存任何类型的数据,数组的大小是可以动态调整的. 创建数组的基本方式: (1)使用Array构造函数 var color=new Array(); ...
- 5.2 Array类型介绍
Array类型是数组类型,Array(数组)类型也是引用类型中的一种. js 数组中的每一项可以保存任何类型的数据. js数组的大小/长度是可以动态调整的.如果你往数组中添加数据,数组长度会自动增加. ...
- JavaScript中Array类型方法总结
Array类型是ECMAScript中最常用的类型之一,ECMAScript中的数组与其他多数语言中的数组有着相当大的区别.ECMAScript数组的每一项可以保存任何类型的数据.这里总结了数组类型的 ...
- Object类型与Array类型
总结--JS中的引用类型: Object类型,Array类型,Boolean类型,Number类型,String类型,Date类型, Function类型,RegExp类型,单体内置对象(Global ...
- [saiku] 使用 Apache Phoenix and HBase 结合 saiku 做大数据查询分析
saiku不仅可以对传统的RDBMS里面的数据做OLAP分析,还可以对Nosql数据库如Hbase做统计分析. 本文简单介绍下一个使用saiku去查询分析hbase数据的例子. 1.phoenix和h ...
随机推荐
- 关于mysql联合索引
1 2 3 4 5 6 7 CREATE TABLE `uniontest` ( `id` int(11) NOT NULL AUTO_INCREMENT, `menuname` varcha ...
- 《从零开始学Swift》学习笔记(Day 41)——类的继承
原创文章,欢迎转载.转载请注明:关东升的博客 Swift中的继承只能发生在类上,不能发生在枚举和结构体上.一个类可以继承另一个类的方法.属性.下标等特征,当一个类继承其他类时,继承类叫子类,被继承类叫 ...
- js引入方式的弹框方法2
html代码: <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv=& ...
- spring多数据源事务配置
项目中遇到多数据源问题, 对于每个数据源需要单独完成事务控制, 这里记录下具体实现方法 在spring配置文件中 定义两个数据源 <!-- 数据源定义(spring-jndi) --> ...
- 基础篇-java开发
开局必知 1.变量 在java中,以{}为作用域,所以就存在成员变量和局部变量之说 由于java是强类型语言,所以在申明变量的时候,必须指定类型 java里,一个变量有声明过程和初始化过程(也就是赋值 ...
- Java的OO与多态
this的用法 class Banana { void f(int i) {} }Banana a = new Banana(), b = new Banana();a.f(1);b.f(2);若只有 ...
- 剑指offer 面试49题
面试49题: 题:丑数 题目:把只包含因子2.3和5的数称作丑数(Ugly Number).例如6.8都是丑数,但14不是,因为它包含因子7. 习惯上我们把1当做是第一个丑数.求按从小到大的顺序的第N ...
- 在像Angular2这样的SPA应用中使用Google Analytics的方法
Angular2のようなシングルページアプリケーションでGoogleアナリティクスを使う方法 如何在像Angular2这样的SPA应用中使用Google Analytics? 试着调查了一下. 由于S ...
- Java多线程(Java总结篇)
Java总结篇:Java多线程 多线程作为Java中很重要的一个知识点,在此还是有必要总结一下的. 一.线程的生命周期及五种基本状态 关于Java中线程的生命周期,首先看一下下面这张较为经典的图: 上 ...
- Redis慢查询,redis-cli,redis-benchmark,info
一.慢查询: 1.慢查询的作用:通过慢查询分析,找到有问题的命令进行优化. 2.慢查询的redis的配置参数: slowlog-log-slower-than 慢查询预设阈值(单位是微秒1秒=1000 ...