postgresql 数组类型
来源:互联网 发布:成都企业网站排名优化 编辑:程序博客网 时间:2024/05/08 16:30
--pg支持数组,且支持分片访问,比如[1:2],任意只有一个数字(没有冒号)的维数是从 1 开始到声明的数字为止的 --如果任意维数被写为一个片段,也就是,包含一个冒号,那么所有维数都被当做是片段If any dimension is written as a slice, i.e., contains a colon, then all dimensions are treated as slices. Any dimension that has only a single number (no colon) is treated as being from 1 to the number specified. For example, [2] is treated as [1:2], as in this example:SELECT schedule[1:2][2] FROM sal_emp WHERE name = 'Bill';--任何数组的当前维数都可以用 array_dims 函数检索:SELECT array_dims(schedule) FROM sal_emp WHERE name = 'Carol';array_dims------------[1:2][1:2]--也可以用 array_upper 和 array_lower 函数分别返回数组特定维的上界和下界:SELECT array_upper(schedule, 1) FROM sal_emp WHERE name = 'Carol'--如果数组本身或任何下标表达式是 NULL ,那么该数组的下标表达式也将生NULL 。 从一个数组的当前范围之外抓取数据将生成一个 NULL ,而不是导致错误 --array_length可用于返回指定维数的长充SELECT array_length(schedule, 1) FROM sal_emp WHERE name = 'Carol';array_length--------------2--cardinality 返回任意维数的元素个数--cardinality returns the total number of elements in an array across all dimensions. It is effectively the number of rows a call to unnest would yield:SELECT cardinality(schedule) FROM sal_emp WHERE name = 'Carol';cardinality-------------4--更新指定索引的数组值UPDATE sal_emp SET pay_by_quarter[4] = 15000 WHERE name = 'Bill';--更新指定分片的数组值UPDATE sal_emp SET pay_by_quarter[1:2] = '{27000,27000}' WHERE name = 'Carol';--可以通过给一个尚不存在数组元素赋值的办法扩大数组, 所有位于原数组最后一个元素和这个新元素之间的未赋值元素都将设为 NULL 。 --例如,如果 myarray数组当前有 4 个元素, 在对 myarray[6]赋值之后它将拥有 6 个元素,其中myarray[5] 的值将为 NULL--检索数组中是否包含任一元素,或者包含所有的元素SELECT * FROM sal_emp WHERE 10000 = ANY (pay_by_quarter);SELECT * FROM sal_emp WHERE 10000 = ALL (pay_by_quarter);--检索数组包含元素的索引,注意第一个函数匹配第一次满足条件的,第二个函数匹配所有的满足条件的SELECT array_position(ARRAY['sun','mon','tue','wed','thu','fri','sat','mon'], 'mon'),array_positions(ARRAY[1, 4, 3, 1, 3, 4, 2, 1], 1); array_position | array_positions ----------------+----------------- 2 | {1,4,8} --数组运算中的一些比较符运算符 描述a = b 立方体a和b是相同的a && b 立方体a和b重叠a @> b 立方体a包含立方体ba <@ b 立方体a被包含在立方体b中[a, b] < [c, d] 小于[a, b] > [c, d] 大于postgres=# select array[1,2,3],array[2,3,4]; array | array ---------+--------- {1,2,3} | {2,3,4}--两个群组中是否有重叠 postgres=# select array[1,2,3]&&array[2,3,4]; ?column? ---------- t--第一个数组是否包含第二个数组postgres=# select array[1,2,3]@>array[2,3,4]; ?column? ---------- f postgres=# select array[1,2,3]@>array[2,3]; ?column? ---------- t--第一个数组是否被第二个数组包含 postgres=# select array[1,2,3]<@array[2,3]; ?column? ---------- f postgres=# select array[1,2,3]<@array[1,2,3,4]; ?column? ---------- t(1 row)
0 0
- postgresql 数组类型
- postgresql自定义类型并返回数组
- PostgreSQL学习篇9.17 数组类型
- java mybatis操作 postgresql array数组类型
- PostgreSQL: array 数组类型添加元素 数组的使用
- PostgreSQL字段类型说明
- PostgreSQL的日志类型
- PostgreSQL基本知识:数值类型
- PostgreSQL 类型转换
- postgresql 修改字段类型
- PostgreSQL 类型转换
- postgresql 索引类型
- postgreSQL 类型转换
- postgresql 索引类型
- PostgreSQL改变字段类型
- POSTGRESQL 数据库 常用类型
- postgresql 操作point类型
- PostgreSQL的日志类型
- 记住今天的选择
- Java RSA格式 转换与运算
- 图文解释XCode常用快捷键的使用
- 解决http转https在chrome里blocked的问题
- POJ 2676 Sudokou DFS
- postgresql 数组类型
- UrlRewriteFilter url过滤
- 2.Flask 路由以及对应的模板
- Install YouTube-DL – A Command Line Video Download Tool for Linux
- 时间戳转化为日期TimeStamp转NSDate转NSString
- telnet命令 测试端口连接是否正常
- linux shell用法(7)-- grep命令
- 【高性能】Matlab的并行计算之parfor
- application对象