postgresql-从子查询中构造数组

本文介绍了如何在PostgreSQL中使用子查询来构造数组的方法,通过具体的SQL语句示例展示了如何从两个表中联接数据,并将结果组织成数组形式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

声明:本PostgreSQl实用指南系列为刘兴(http://deepfuture.iteye.com/)原创,未经笔者授权,任何人和机构不能转载

子查询的结果中构造一个数组

D:\pgsql>psql mydb
psql (8.4.2)
Type "help" for help.

mydb=#
mydb=# select * from student,citys where student.city=citys.id
mydb-# ;
    name    | age | city |  sex  | name | id
------------+-----+------+-------+------+----
 艾丝凡     |  18 |    3 |       | 上海 |  3
 萨芬       |  19 |    3 |       | 上海 |  3
 未来       |  20 |    2 | man   | 湛江 |  2
 干哈       |  18 |    2 | man   | 湛江 |  2
 deepfuture |  20 |    1 | woman | 长沙 |  1
 张三       |  21 |    1 | woman | 长沙 |  1
 王五       |  25 |    3 | man   | 上海 |  3
 李白       |  23 |    2 | man   | 湛江 |  2
 李国       |  24 |    1 | woman | 长沙 |  1
(9 rows)

 


mydb=# select citys.name as 城市,array(select name from student where student.ci
ty=citys.id) as 学生 from citys;
 城市 |          学生
------+------------------------
 长沙 | {deepfuture,张三,李国}
 湛江 | {未来,干哈,李白}
 上海 | {艾丝凡,萨芬,王五}
(3 rows)


mydb=# select * from student;
    name    | age | city |  sex
------------+-----+------+-------
 艾丝凡     |  18 |    3 |
 萨芬       |  19 |    3 |
 未来       |  20 |    2 | man
 干哈       |  18 |    2 | man
 deepfuture |  20 |    1 | woman
 张三       |  21 |    1 | woman
 王五       |  25 |    3 | man
 李白       |  23 |    2 | man
 李国       |  24 |    1 | woman
(9 rows)


mydb=# select * from citys;
 name | id
------+----
 长沙 |  1
 湛江 |  2
 上海 |  3
(3 rows)


mydb=#

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值