文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

PostgreSQL -- 数组类型操作

2024-04-02 19:55

关注

一、数组类型创建表

数组类型,要求数组内的元素属于同一种类型,当出现No function matches the given name and argument types. You might need to add explicit type casts.报错的时候,说明 list 的格式和插入数据或者修改数据的格式不同导致的, 类型很重要,需要保证类型相同才可以操作
 

1.1、建表指定数组类型

只需要在表字段类型后面加'[]'

postgres=# create table test1 (
    id serial, 
    arr int[], 
    name varchar(10)[], 
    age char(10)[], 
    score float[]
    ); 

postgres=# \d+ test1;
                                                 Table "public.test1"
     Column |          Type           |                     Modifiers                      | Storage  | Stats target | Description 
--------+-------------------------+----------------------------------------------------+----------+--------------+-------------
 id     | integer                 | not null default nextval('test1_id_seq'::regclass) | plain    |              | 
 arr    | integer[]               |                                                    | extended |              | 
 name   | character varying(10)[] |                                                    | extended |              | 
 age    | character(10)[]         |                                                    | extended |              | 
 score  | double precision[]      |                                                    | extended |              | 

 

1.2、数据插入

postgres=# insert into test(id, uid) values(3, '{1, 2, 3}');        插入数组方式1
postgres=# insert into test(id, uid) values(3, array[20, 30]::int8[]);   插入数组方式二

1.3、修改数组:

postgres=# update test set uid = uid || '{0}';    后面追加一个数组
postgres=# update test set uid='{0,0}' || uid;   在前面插入一个数组
postgres=# update arr_test set uid=array_append(uid, '1'::int);   指明类型追加一个数
postgres=# update arr_test set uid=array_append(uid, 1);   按默认int类型追加一个数
postgres=# update arr_test set uid=array_prepend('1'::int, uid);     在前面插入一个数

1.4、删除数组中的数据

postgres=# update arr_test set uid=array_remove(uid, '1'::int);  指明类型移除指定的数

1.5、查找数组中的数据

postgres=# select * from test where 20=any(uid);    #uid数组中存在20的row
postgres=# select * from test where uid && array[20, 1]::int8[];   uid数组中和array[20, 1]存在交集的
postgres=# select * from arr_test where uid@>'{1, 2}';   uid 数组中同时包含[1, 2]的
postgres=# select * from arr_test where uid<@'{1, 2}';   uid 数组被[1, 2]包含的

postgres=# select * from arr_test where 2=uid[1]; 使用uid 数组下标查询,下标是从1开始的
postgres=# select id, uid[2] from arr_test; 使用下标显示

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯