arrays.out 2.36 KB
Newer Older
1 2 3 4 5 6 7 8 9
--
-- ARRAYS
--
SELECT * FROM arrtest;
      a      |        b        |       c       |         d         |       e       |         f         |        g        
-------------+-----------------+---------------+-------------------+---------------+-------------------+-----------------
 {1,2,3,4,5} | {{{0,0},{1,2}}} | {}            | {}                |               | {}                | {}
 {11,12,23}  | {{3,4},{4,5}}   | {"foobar"}    | {{"elt1","elt2"}} | {"3.4","6.7"} | {"abc  ","abcde"} | {"abc","abcde"}
 {}          | {3,4}           | {"foo","bar"} | {"bar","foo"}     |               |                   | 
10 11
(3 rows)

12
SELECT arrtest.a[1],
13 14
          arrtest.b[1][1][1],
          arrtest.c[1],
15
          arrtest.d[1][1], 
16 17
          arrtest.e[0]
   FROM arrtest;
18 19 20 21 22
 a  | b |   c    |  d   | e 
----+---+--------+------+---
  1 | 0 |        |      |  
 11 |   | foobar | elt1 |  
    |   | foo    |      |  
23 24
(3 rows)

25
SELECT a[1], b[1][1][1], c[1], d[1][1], e[0]
26
   FROM arrtest;
27 28 29 30 31
 a  | b |   c    |  d   | e 
----+---+--------+------+---
  1 | 0 |        |      |  
 11 |   | foobar | elt1 |  
    |   | foo    |      |  
32 33
(3 rows)

34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
SELECT a[1:3],
          b[1:1][1:2][1:2],
          c[1:2], 
          d[1:1][1:2]
   FROM arrtest;
     a      |        b        |       c       |         d         
------------+-----------------+---------------+-------------------
 {1,2,3}    | {{{0,0},{1,2}}} |               | 
 {11,12,23} |                 |               | {{"elt1","elt2"}}
            |                 | {"foo","bar"} | 
(3 rows)

-- returns three different results--
SELECT array_dims(arrtest.b) AS x;
        x        
-----------------
 [1:1][1:2][1:2]
 [1:2][1:2]
 [1:2]
53 54
(3 rows)

55 56
-- returns nothing 
SELECT *
57
   FROM arrtest
58 59 60 61
   WHERE a[1] < 5 and 
         c = '{"foobar"}'::_name;
 a | b | c | d | e | f | g 
---+---+---+---+---+---+---
62 63
(0 rows)

64 65 66 67 68 69 70 71
UPDATE arrtest
  SET a[1:2] = '{16,25}',
      b[1:1][1:1][1:2] = '{113, 117}', 
      c[1:1] = '{"new_word"}';
SELECT a[1:3],
          b[1:1][1:2][1:2],
          c[1:2], 
          d[1:1][2:2]
72
   FROM arrtest;
73 74 75 76 77
     a      |          b          |         c          |     d      
------------+---------------------+--------------------+------------
 {16,25,3}  | {{{113,117},{1,2}}} |                    | 
 {16,25,23} |                     |                    | {{"elt2"}}
            |                     | {"new_word","bar"} | 
78 79
(3 rows)