zoukankan      html  css  js  c++  java
  • 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=# 
  • 相关阅读:
    Windows开发,关于通过写代码加载PDB的那些事
    从FreeBSD里面看到的网络协议列表,感觉可以保存一下
    听了几段《双投唐》
    ReactOS 无法显示中文的问题
    ReactOS 代码更新后的编译安装
    都什么年代了,怎么还那种德行
    假冒不伪劣
    ollvm 使用——“Cannot open /dev/random”错误的解决方法
    ollvm 编译
    C/C++ 吐槽第一期:你最讨厌的C/C++里面的数据类型是什么
  • 原文地址:https://www.cnblogs.com/gaojian/p/3190737.html
Copyright © 2011-2022 走看看