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类型的更多相关文章

  1. phoenix 报错:type org.apache.phoenix.schema.types.PhoenixArray is not supported

    今天用phoenix报如下错误: 主要原因: hbase的表中某字段类型是array,phoenix目前不支持此类型 解决方法: 复制替换phoenix包的cursor文件 # Copyright 2 ...

  2. Apache Phoenix系列 | 从入门到精通(转载)

    原文地址:https://cloud.tencent.com/developer/article/1498057 来源: 云栖社区 作者: 瑾谦 By 大数据技术与架构 文章简介:Phoenix是一个 ...

  3. Apache Phoenix基本操作-1

    本篇我们将介绍phoenix的一些基本操作. 1. 如何使用Phoenix输出Hello World? 1.1 使用sqlline终端命令 sqlline.py SZB-L0023780:2181:/ ...

  4. Apache Phoenix基本操作-2

    1. 如何映射一个Phoenix的表到一个Hbase的表? 你可以通过Create table/create view DDL语句在一个已经存在的hbase表上创建一个Phoenix表或者视图.对于C ...

  5. JS高程5.引用类型(2)Array类型

    Array类型: ECMAScript数组的每一项可以保存任何类型的数据,数组的大小是可以动态调整的. 创建数组的基本方式: (1)使用Array构造函数 var color=new Array(); ...

  6. 5.2 Array类型介绍

    Array类型是数组类型,Array(数组)类型也是引用类型中的一种. js 数组中的每一项可以保存任何类型的数据. js数组的大小/长度是可以动态调整的.如果你往数组中添加数据,数组长度会自动增加. ...

  7. JavaScript中Array类型方法总结

    Array类型是ECMAScript中最常用的类型之一,ECMAScript中的数组与其他多数语言中的数组有着相当大的区别.ECMAScript数组的每一项可以保存任何类型的数据.这里总结了数组类型的 ...

  8. Object类型与Array类型

    总结--JS中的引用类型: Object类型,Array类型,Boolean类型,Number类型,String类型,Date类型, Function类型,RegExp类型,单体内置对象(Global ...

  9. [saiku] 使用 Apache Phoenix and HBase 结合 saiku 做大数据查询分析

    saiku不仅可以对传统的RDBMS里面的数据做OLAP分析,还可以对Nosql数据库如Hbase做统计分析. 本文简单介绍下一个使用saiku去查询分析hbase数据的例子. 1.phoenix和h ...

随机推荐

  1. iOS学习笔记(一)——ios搭建开发环境

    好久就想试水IOS开发了,由于开发环境限制,一直局限于理论和虚拟机,近来入手了MacBook Pro,也来尝尝鲜,笔者也是现学现总结,如果有不足,请指正. IOS开发必备MAC OS X 另加一部iP ...

  2. 3673: 可持久化并查集 by zky

    3673: 可持久化并查集 by zky Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 2170  Solved: 978[Submit][Status ...

  3. 坑爹的 HTTPClient java.lang.NoSuchFieldError: INSTANCE

    项目中需要用到httpclient ,maven配置如下 <dependency> <groupId>org.apache.httpcomponents</groupId ...

  4. 巨蟒python全栈开发linux之centos2

    1.一些命令回顾 在vm中,右击"打开终端",输入命令ifconfig,得到的下图算是一个终端,并且我们可以看到服务器的ip是192.168.34.128 我们通过windows上 ...

  5. VSpy之C Code Interface的使用

    Spy3 要运行 CCodeInterface 功能,需要安装运行环境,建议安装 Visual Studio2003,2005,2008,2010 或更新的版本.当然也可以安装 VC express ...

  6. Wireshark网络分析工具(二)

    一.TCP三次握手过称 1. 第一次握手的数据包 客户端发送一个TCP,标志位为SYN,序列号为0, 代表客户端请求建立连接. 如下图: 2. 第二次握手的数据包 服务器发回确认包, 标志位为 SYN ...

  7. 0x07 MySQL 多表查询

    Some Content From——Egon's Blog http://www.cnblogs.com/linhaifeng/articles/7126847.html 一 准备表 准备表 #建表 ...

  8. 0x04 MySQl 表操作

    0x01 存储引擎介绍 存储引擎即表类型,mysql根据不同的表类型会有不同的处理机制 详见:http://www.cnblogs.com/linhaifeng/articles/7213670.ht ...

  9. MyISAM VS InnoDB

     A.构成上的区别: InnoDB只在磁盘上存储一个文件.frm         每个MyISAM在磁盘上存储成三个文件.第一个文件的名字以表的名字开始,扩展名指出文件类型:            文 ...

  10. swift笔记——环境搭建及Hello,Swift!

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/enson16855/article/details/29829601 首先要下载XCode6,仅仅有 ...