PostgreSQL中的数组与Any

建立表:

CREATE TABLE sal_emp (
name            text,
pay_by_quarter  integer[],
schedule        text[][]
);

插入数据:

复制代码
INSERT INTO sal_emp
  VALUES ('Bill',
  ARRAY[10000, 11000, 9000, 13000],
  ARRAY[['meeting', 'lunch'], ['training', 'presentation']]);

INSERT INTO sal_emp
  VALUES ('Carol',
  ARRAY[20000, 25000, 25000, 25000],
  ARRAY[['breakfast', 'consulting'], ['meeting', 'lunch']]);

INSERT INTO sal_emp
  VALUES ('Frank',
  ARRAY[10000, 10000, 10000, 10000],
  ARRAY[['breakfast', 'training'], ['meeting', 'lunch']]);
复制代码

查看:

复制代码
pgsql=# SELECT * FROM sal_emp;
 name  |      pay_by_quarter       |                 schedule                  
-------+---------------------------+-------------------------------------------
 Bill  | {10000,11000,9000,13000}  | {{meeting,lunch},{training,presentation}}
 Carol | {20000,25000,25000,25000} | {{breakfast,consulting},{meeting,lunch}}
 Frank | {10000,10000,10000,10000} | {{breakfast,training},{meeting,lunch}}
(3 rows)

pgsql=# 
复制代码

用Any来查询:

复制代码
pgsql=# SELECT * FROM sal_emp WHERE 10000 = ANY (pay_by_quarter);
 name  |      pay_by_quarter       |                 schedule                  
-------+---------------------------+-------------------------------------------
 Bill  | {10000,11000,9000,13000}  | {{meeting,lunch},{training,presentation}}
 Frank | {10000,10000,10000,10000} | {{breakfast,training},{meeting,lunch}}
(2 rows)

pgsql=# 
复制代码

用ALL来查询:

复制代码
pgsql=# SELECT * FROM sal_emp WHERE 10000 = ALL (pay_by_quarter);
 name  |      pay_by_quarter       |                schedule                
-------+---------------------------+----------------------------------------
 Frank | {10000,10000,10000,10000} | {{breakfast,training},{meeting,lunch}}
(1 row)

pgsql=# 
复制代码

用下标来查询:

复制代码
pgsql=# SELECT * FROM sal_emp WHERE 9000 = pay_by_quarter[3];
 name |      pay_by_quarter      |                 schedule                  
------+--------------------------+-------------------------------------------
 Bill | {10000,11000,9000,13000} | {{meeting,lunch},{training,presentation}}
(1 row)

pgsql=# 
复制代码






  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值