添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

PostgreSQL支持字段使用定长或可变长的一维或多维数组。数组的类型可以是内建类型,自定义类型,枚举类型以及组合类型。目前不支持区域类型。

create table test(
  id int,
  coll int[]

    目前PostgreSQL中,声明数组长度和数组维度是没有意义的,根据实际插入的数据确定。

2.插入数据

     数组的输入使用单引号‘’加大括号{}表示,各个元素简用逗号分隔。

insert into test values(1,'{1,2,3}');
insert into test values(2,'{4,5,6}');

   也可以使用ARRAY构造器也可以输入数组数据。有关键字ARRAY,方括号[]和逗号分隔的元素值组成。

insert into test values(3,array[7,8,9]);
insert into test values(4,array[4,5,6]);

3.访问数组

select * from test;

    访问数组中的元素时,在方括号内加数字就可以了,数组的下标默认从1开始。

select id, coll[1] from test;

    还可以使用数组的切片。

select id, coll[2:3] from test;

4.修改数组

    数组值可以整个替换,也可以只替换数组中的单个元素。

    替换整个数组值。

update test set coll='{1,1,1}' where id=1;

   替换数组中某一个元素值。

update test set coll[1] = 0 where id =1;
    PostgreSQL支持字段使用定长或可变长的一维或多维数组。数组的类型可以是内建类型,自定义类型,枚举类型以及组合类型。目前不支持区域类型。1.建表create table test( id int, coll int[]);    目前PostgreSQL中,声明数组长度和数组维度是没有意义的,根据实际插入的数据确定。2.插入数据     数组的输入使用...
PostgreSQL表字段类型可以使用定长或可变长度的数组数组类型可以是任何数据库内建的类型、用户自定义的类型、枚举类型或组合类型。 一、数组的声明 先来看例子: postgres=# create table a( id int primary key, vi int[], vt...
create_table :table_with_arrays do |t| t.integer :int_array, :array => true # integer[] t.integer :int_array, :array => true, :length => 2 # smallint[] t.string :st PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (数据表 数据表 ) 4 一、表的定义: 一、表的定义: 一、表的定义: . 4 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (模式 Schema) Schema) .9 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (表的继承和分区 表的继承和分区 表的继承和分区 表的继承和分区 ) 10 一、表的继承: 一、表的继承: 一、表的继承: .10 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (常用数据类型 常用数据类型 常用数据类型 ) 16 一、数值类型: 一、数值类型: 一、数值类型: .16 六、数组: 六、数组: .22 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (函数和操作符 函数和操作符 函数和操作符 <一>) 25 一、逻辑操作符: 一、逻辑操作符: 一、逻辑操作符: 一、逻辑操作符: .25 四、字符串函数和操作: 四、字符串函数和操作: 四、字符串函数和操作: 四、字符串函数和操作: 四、字符串函数和操作: 四、字符串函数和操作: .27 五、位串函数和操作符: 五、位串函数和操作符: 五、位串函数和操作符: 五、位串函数和操作符: 五、位串函数和操作符: .29 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (函数和操作符 函数和操作符 函数和操作符 <二>) 30 六、模式匹配: 六、模式匹配: 六、模式匹配: .30 八、时间 八、时间 /日期函数和操作符: 日期函数和操作符: 日期函数和操作符: 日期函数和操作符: 日期函数和操作符: 33 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (函数和操作符 函数和操作符 函数和操作符 <三>) 35 九、序列操作函数: 九、序列操作函数: 九、序列操作函数: 九、序列操作函数: . 35 十二、系统信息 十二、系统信息 十二、系统信息 函数: 函数: .38 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (索引 ) 42 一、索引的类型: 一、索引的类型: 一、索引的类型: 一、索引的类型: .42 四、唯一索引: 四、唯一索引: 四、唯一索引: .43 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (事物隔离 事物隔离 ) 45 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (性能提升技巧 性能提升技巧 性能提升技巧 ) 46 一、使用 一、使用 EXPLAINEXPLAINEXPLAINEXPLAIN EXPLAIN: 46 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (服务器配置 服务器配置 服务器配置 ) 50 一、服务器进程的启动和关闭: 一、服务器进程的启动和关闭: 一、服务器进程的启动和关闭: 一、服务器进程的启动和关闭: 一、服务器进程的启动和关闭: 一、服务器进程的启动和关闭: . 50 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (角色和权限 角色和权限 角色和权限 ) 52 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (数据库管理 数据库管理 数据库管理 ) 54 一、概述: 一、概述: .54 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (数据库维护 数据库维护 数据库维护 ) 56 一、恢复磁盘空间: 一、恢复磁盘空间: 一、恢复磁盘空间: 一、恢复磁盘空间: . 56 二、更新规划器统计: 二、更新规划器统计: 二、更新规划器统计: 二、更新规划器统计: 二、更新规划器统计: .57 四、定期重建索引: 四、定期重建索引: 四、定期重建索引: 四、定期重建索引: . 59 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (系统表 系统表 ) 61 一、 pg_class: pg_class: pg_class: pg_class:pg_class: 61 三、 pg_attrdef: pg_attrdef: pg_attrdef:pg_attrdef:pg_attrdef:pg_attrdef:pg_attrdef:pg_attrdef:pg_attrdef: . 63 四、 pg_authid: pg_authid: pg_authid: pg_authid:pg_authid: 64 五、 pg_auth_members: pg_auth_members: pg_auth_members: pg_auth_members:pg_auth_members: pg_auth_members:pg_auth_members:pg_auth_members:pg_auth_members: .64 七、 pg_tablespace: pg_tablespace: pg_tablespace: pg_tablespace: pg_tablespace: pg_tablespace:pg_tablespace: .65 十、 pg_index: pg_index: pg_index:pg_index:pg_index:pg_index: . 67 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (系统视图 系统视图 ) 68 一、 pg_tables: pg_tables: pg_tables: pg_tables: pg_tables: 68 二、 pg_indexes: pg_indexes: pg_indexes:pg_indexes:pg_indexes:pg_indexes: 68 三、 pg_views: pg_views:pg_views: pg_views: pg_views:pg_views: . 68 四、 pg_user: pg_user: pg_user:pg_user:pg_user: .69 五、 pg _roles:_roles:_roles:_roles: _roles: 69 六、 pg_rules: pg_rules:pg_rules:pg_rules: pg_rules: 69 七、 pg_settings: pg_settings: pg_settings: pg_settings:pg_settings: pg_settings:pg_settings:pg_settings: .70 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (客户端命令 客户端命令 客户端命令 <一>) 70 零、口令文件: 零、口令文件: 零、口令文件: .70 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (客户端命令 客户端命令 客户端命令 <二>) 75 七、 pg_dump: pg_dump: pg_dump:pg_dump:. 75 八、 pg_restore: pg_restore:pg_restore:pg_restore: pg_restore:pg_restore:pg_restore:pg_restore: 77 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (SQL (SQL语言函数 语言函数 ) . 83 一、基本概念: 一、基本概念: 一、基本概念: .83 PostgreSQL PostgreSQL PostgreSQL学习手册 学习手册 学习手册 (PL/pgSQL (PL/pgSQL(PL/pgSQL 过程语言 过程语言 ) .86 一、概述: 一、概述:
本文主要介绍下Postgresql的另外两种特殊的类型Range类型(范围类型)和数组类型。两种类型,适用于不同的场景,但是最终的目的相同,就是使用传统的数据类型,建立常规的索引无法满足查询的性能要求。而使用范围类型(通过使用gist索引)、使用数组类型(通过使用Gin索引)可以大幅度的加快特定场景下数据的查询速度。下面笔者就分别介绍下这两种数据类型的使用。 一、Range类型 1.1 Range类型的使用 在使用Range类型之前,我们先建立一些测试数据,用于Range类...
开发的语言有数组的概念,对应于postgresql也有相关的数据字段类型数组是英文array的翻译,可以定义一维,二维甚至更多维度,数学上跟矩阵很类似。在postgres里面可以直接存储使用,某些场景下使用很方便,也很强大。 OS:CentOS 6.2 DB: PostgreSQL 9.2.41.数组的定义 不一样的维度元素长度定义在数据库的实际存储都是一样的,数组元素的长度和类型必须要保持.
NumPy数值计算基础 NumPy是在1995年诞生的Python库Numeric的基础上建立起来的,但真正促使NumPy的发行的是Python的SciPy库。但SciPy并没有合适的类似于Numeric的对于基础数据对象处理的功能。于是,SciPy的开发者将SciPy的一部分和Numeric的设计思想结合,在2005年发行了NumPy。 NumPy是Python的一种开源的数值计算扩展库。它包含很多功能,如创建n维数组(矩阵)、对数组进行函数运算、数值积分等。 NumPy的诞生弥补了这些缺陷,它提
PostgreSQL 数据类型1. 创建语法回顾2. 数值类型3. 货币类型4. 字符类型5. 日期/时间类型6. 布尔类型7. 枚举类型8. 几何类型9. 网络地址类型10. 位串类型11. 文本搜索类型12. UUID 类型13. XML 类型13.1 创建 XML 值14. JSON 类型15. 数组类型15.1 声明数组15.2 插入值15.3 访问数组15.4 修改数组15.5 数组检索16. 复合类型16.1 声明复合类型16.2 访问复合类型17. 范围类型18. 对象标识符类型19. 伪
可以批量对数组元素进行删除,原文链接 http://blog.163.com/digoal@126/blog/static/163877040201261273149437/,在这篇 blog 德哥新增了函数 multi_text_array_remove (i_src text[],i_remove text[]) 用来应对数组 多个元素删除的情况: 数组 ARRAY[
偶然发现 postgre 支持数组类型,闲着无聊整理了一些数组类型的用法。目前处于探索阶段。 1 创建表 CREATE TABLE test ( ID serial PRIMARY KEY, phone int4 [] ); 查看表结构显示phone字段type:integer[] postgres=# \d test Table "public.test" Column | Type | Collation | Nullable --数组类型的插入方式两种 --第一种 insert into test_array1(id , array_i , array_t) values(1 , '{1,2,3}' , '{"abc","def"}'); --第二种 insert into