~vcs-imports/mammoth-replicator/trunk

« back to all changes in this revision

Viewing changes to src/test/regress/expected/int8-exp-three-digits.out

  • Committer: alvherre
  • Date: 2005-12-16 21:24:52 UTC
  • Revision ID: svn-v4:db760fc0-0f08-0410-9d63-cc6633f64896:trunk:1
Initial import of the REL8_0_3 sources from the Pgsql CVS repository.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
--
 
2
-- INT8
 
3
-- Test int8 64-bit integers.
 
4
--
 
5
CREATE TABLE INT8_TBL(q1 int8, q2 int8);
 
6
INSERT INTO INT8_TBL VALUES('  123   ','  456');
 
7
INSERT INTO INT8_TBL VALUES('123   ','4567890123456789');
 
8
INSERT INTO INT8_TBL VALUES('4567890123456789','123');
 
9
INSERT INTO INT8_TBL VALUES('4567890123456789','4567890123456789');
 
10
INSERT INTO INT8_TBL VALUES('4567890123456789','-4567890123456789');
 
11
-- bad inputs
 
12
INSERT INTO INT8_TBL(q1) VALUES ('      ');
 
13
ERROR:  invalid input syntax for integer: "      "
 
14
INSERT INTO INT8_TBL(q1) VALUES ('xxx');
 
15
ERROR:  invalid input syntax for integer: "xxx"
 
16
INSERT INTO INT8_TBL(q1) VALUES ('3908203590239580293850293850329485');
 
17
ERROR:  value "3908203590239580293850293850329485" is out of range for type bigint
 
18
INSERT INTO INT8_TBL(q1) VALUES ('-1204982019841029840928340329840934');
 
19
ERROR:  value "-1204982019841029840928340329840934" is out of range for type bigint
 
20
INSERT INTO INT8_TBL(q1) VALUES ('- 123');
 
21
ERROR:  invalid input syntax for integer: "- 123"
 
22
INSERT INTO INT8_TBL(q1) VALUES ('  345     5');
 
23
ERROR:  invalid input syntax for integer: "  345     5"
 
24
INSERT INTO INT8_TBL(q1) VALUES ('');
 
25
ERROR:  invalid input syntax for integer: ""
 
26
SELECT * FROM INT8_TBL;
 
27
        q1        |        q2         
 
28
------------------+-------------------
 
29
              123 |               456
 
30
              123 |  4567890123456789
 
31
 4567890123456789 |               123
 
32
 4567890123456789 |  4567890123456789
 
33
 4567890123456789 | -4567890123456789
 
34
(5 rows)
 
35
 
 
36
SELECT '' AS five, q1 AS plus, -q1 AS minus FROM INT8_TBL;
 
37
 five |       plus       |       minus       
 
38
------+------------------+-------------------
 
39
      |              123 |              -123
 
40
      |              123 |              -123
 
41
      | 4567890123456789 | -4567890123456789
 
42
      | 4567890123456789 | -4567890123456789
 
43
      | 4567890123456789 | -4567890123456789
 
44
(5 rows)
 
45
 
 
46
SELECT '' AS five, q1, q2, q1 + q2 AS plus FROM INT8_TBL;
 
47
 five |        q1        |        q2         |       plus       
 
48
------+------------------+-------------------+------------------
 
49
      |              123 |               456 |              579
 
50
      |              123 |  4567890123456789 | 4567890123456912
 
51
      | 4567890123456789 |               123 | 4567890123456912
 
52
      | 4567890123456789 |  4567890123456789 | 9135780246913578
 
53
      | 4567890123456789 | -4567890123456789 |                0
 
54
(5 rows)
 
55
 
 
56
SELECT '' AS five, q1, q2, q1 - q2 AS minus FROM INT8_TBL;
 
57
 five |        q1        |        q2         |       minus       
 
58
------+------------------+-------------------+-------------------
 
59
      |              123 |               456 |              -333
 
60
      |              123 |  4567890123456789 | -4567890123456666
 
61
      | 4567890123456789 |               123 |  4567890123456666
 
62
      | 4567890123456789 |  4567890123456789 |                 0
 
63
      | 4567890123456789 | -4567890123456789 |  9135780246913578
 
64
(5 rows)
 
65
 
 
66
SELECT '' AS three, q1, q2, q1 * q2 AS multiply FROM INT8_TBL;
 
67
ERROR:  bigint out of range
 
68
SELECT '' AS three, q1, q2, q1 * q2 AS multiply FROM INT8_TBL
 
69
 WHERE q1 < 1000 or (q2 > 0 and q2 < 1000);
 
70
 three |        q1        |        q2        |      multiply      
 
71
-------+------------------+------------------+--------------------
 
72
       |              123 |              456 |              56088
 
73
       |              123 | 4567890123456789 | 561850485185185047
 
74
       | 4567890123456789 |              123 | 561850485185185047
 
75
(3 rows)
 
76
 
 
77
SELECT '' AS five, q1, q2, q1 / q2 AS divide FROM INT8_TBL;
 
78
 five |        q1        |        q2         |     divide     
 
79
------+------------------+-------------------+----------------
 
80
      |              123 |               456 |              0
 
81
      |              123 |  4567890123456789 |              0
 
82
      | 4567890123456789 |               123 | 37137318076884
 
83
      | 4567890123456789 |  4567890123456789 |              1
 
84
      | 4567890123456789 | -4567890123456789 |             -1
 
85
(5 rows)
 
86
 
 
87
SELECT '' AS five, q1, float8(q1) FROM INT8_TBL;
 
88
 five |        q1        |        float8         
 
89
------+------------------+-----------------------
 
90
      |              123 |                   123
 
91
      |              123 |                   123
 
92
      | 4567890123456789 | 4.56789012345679e+015
 
93
      | 4567890123456789 | 4.56789012345679e+015
 
94
      | 4567890123456789 | 4.56789012345679e+015
 
95
(5 rows)
 
96
 
 
97
SELECT '' AS five, q2, float8(q2) FROM INT8_TBL;
 
98
 five |        q2         |         float8         
 
99
------+-------------------+------------------------
 
100
      |               456 |                    456
 
101
      |  4567890123456789 |  4.56789012345679e+015
 
102
      |               123 |                    123
 
103
      |  4567890123456789 |  4.56789012345679e+015
 
104
      | -4567890123456789 | -4.56789012345679e+015
 
105
(5 rows)
 
106
 
 
107
SELECT '' AS five, 2 * q1 AS "twice int4" FROM INT8_TBL;
 
108
 five |    twice int4    
 
109
------+------------------
 
110
      |              246
 
111
      |              246
 
112
      | 9135780246913578
 
113
      | 9135780246913578
 
114
      | 9135780246913578
 
115
(5 rows)
 
116
 
 
117
SELECT '' AS five, q1 * 2 AS "twice int4" FROM INT8_TBL;
 
118
 five |    twice int4    
 
119
------+------------------
 
120
      |              246
 
121
      |              246
 
122
      | 9135780246913578
 
123
      | 9135780246913578
 
124
      | 9135780246913578
 
125
(5 rows)
 
126
 
 
127
-- TO_CHAR()
 
128
--
 
129
SELECT '' AS to_char_1, to_char(q1, '9G999G999G999G999G999'), to_char(q2, '9,999,999,999,999,999') 
 
130
        FROM INT8_TBL;
 
131
 to_char_1 |        to_char         |        to_char         
 
132
-----------+------------------------+------------------------
 
133
           |                    123 |                    456
 
134
           |                    123 |  4,567,890,123,456,789
 
135
           |  4,567,890,123,456,789 |                    123
 
136
           |  4,567,890,123,456,789 |  4,567,890,123,456,789
 
137
           |  4,567,890,123,456,789 | -4,567,890,123,456,789
 
138
(5 rows)
 
139
 
 
140
SELECT '' AS to_char_2, to_char(q1, '9G999G999G999G999G999D999G999'), to_char(q2, '9,999,999,999,999,999.999,999') 
 
141
        FROM INT8_TBL;  
 
142
 to_char_2 |            to_char             |            to_char             
 
143
-----------+--------------------------------+--------------------------------
 
144
           |                    123.000,000 |                    456.000,000
 
145
           |                    123.000,000 |  4,567,890,123,456,789.000,000
 
146
           |  4,567,890,123,456,789.000,000 |                    123.000,000
 
147
           |  4,567,890,123,456,789.000,000 |  4,567,890,123,456,789.000,000
 
148
           |  4,567,890,123,456,789.000,000 | -4,567,890,123,456,789.000,000
 
149
(5 rows)
 
150
 
 
151
SELECT '' AS to_char_3, to_char( (q1 * -1), '9999999999999999PR'), to_char( (q2 * -1), '9999999999999999.999PR') 
 
152
        FROM INT8_TBL;
 
153
 to_char_3 |      to_char       |        to_char         
 
154
-----------+--------------------+------------------------
 
155
           |              <123> |              <456.000>
 
156
           |              <123> | <4567890123456789.000>
 
157
           | <4567890123456789> |              <123.000>
 
158
           | <4567890123456789> | <4567890123456789.000>
 
159
           | <4567890123456789> |  4567890123456789.000 
 
160
(5 rows)
 
161
 
 
162
SELECT '' AS to_char_4, to_char( (q1 * -1), '9999999999999999S'), to_char( (q2 * -1), 'S9999999999999999') 
 
163
        FROM INT8_TBL;
 
164
 to_char_4 |      to_char      |      to_char      
 
165
-----------+-------------------+-------------------
 
166
           |              123- |              -456
 
167
           |              123- | -4567890123456789
 
168
           | 4567890123456789- |              -123
 
169
           | 4567890123456789- | -4567890123456789
 
170
           | 4567890123456789- | +4567890123456789
 
171
(5 rows)
 
172
 
 
173
SELECT '' AS to_char_5,  to_char(q2, 'MI9999999999999999')     FROM INT8_TBL;   
 
174
 to_char_5 |      to_char      
 
175
-----------+-------------------
 
176
           |               456
 
177
           |  4567890123456789
 
178
           |               123
 
179
           |  4567890123456789
 
180
           | -4567890123456789
 
181
(5 rows)
 
182
 
 
183
SELECT '' AS to_char_6,  to_char(q2, 'FMS9999999999999999')    FROM INT8_TBL;
 
184
 to_char_6 |      to_char      
 
185
-----------+-------------------
 
186
           | +456
 
187
           | +4567890123456789
 
188
           | +123
 
189
           | +4567890123456789
 
190
           | -4567890123456789
 
191
(5 rows)
 
192
 
 
193
SELECT '' AS to_char_7,  to_char(q2, 'FM9999999999999999THPR') FROM INT8_TBL;
 
194
 to_char_7 |      to_char       
 
195
-----------+--------------------
 
196
           | 456TH
 
197
           | 4567890123456789TH
 
198
           | 123RD
 
199
           | 4567890123456789TH
 
200
           | <4567890123456789>
 
201
(5 rows)
 
202
 
 
203
SELECT '' AS to_char_8,  to_char(q2, 'SG9999999999999999th')   FROM INT8_TBL;   
 
204
 to_char_8 |       to_char       
 
205
-----------+---------------------
 
206
           | +             456th
 
207
           | +4567890123456789th
 
208
           | +             123rd
 
209
           | +4567890123456789th
 
210
           | -4567890123456789
 
211
(5 rows)
 
212
 
 
213
SELECT '' AS to_char_9,  to_char(q2, '0999999999999999')       FROM INT8_TBL;   
 
214
 to_char_9 |      to_char      
 
215
-----------+-------------------
 
216
           |  0000000000000456
 
217
           |  4567890123456789
 
218
           |  0000000000000123
 
219
           |  4567890123456789
 
220
           | -4567890123456789
 
221
(5 rows)
 
222
 
 
223
SELECT '' AS to_char_10, to_char(q2, 'S0999999999999999')      FROM INT8_TBL;   
 
224
 to_char_10 |      to_char      
 
225
------------+-------------------
 
226
            | +0000000000000456
 
227
            | +4567890123456789
 
228
            | +0000000000000123
 
229
            | +4567890123456789
 
230
            | -4567890123456789
 
231
(5 rows)
 
232
 
 
233
SELECT '' AS to_char_11, to_char(q2, 'FM0999999999999999')     FROM INT8_TBL;   
 
234
 to_char_11 |      to_char      
 
235
------------+-------------------
 
236
            | 0000000000000456
 
237
            | 4567890123456789
 
238
            | 0000000000000123
 
239
            | 4567890123456789
 
240
            | -4567890123456789
 
241
(5 rows)
 
242
 
 
243
SELECT '' AS to_char_12, to_char(q2, 'FM9999999999999999.000') FROM INT8_TBL;
 
244
 to_char_12 |        to_char        
 
245
------------+-----------------------
 
246
            | 456.000
 
247
            | 4567890123456789.000
 
248
            | 123.000
 
249
            | 4567890123456789.000
 
250
            | -4567890123456789.000
 
251
(5 rows)
 
252
 
 
253
SELECT '' AS to_char_13, to_char(q2, 'L9999999999999999.000')  FROM INT8_TBL;   
 
254
 to_char_13 |        to_char         
 
255
------------+------------------------
 
256
            |                456.000
 
257
            |   4567890123456789.000
 
258
            |                123.000
 
259
            |   4567890123456789.000
 
260
            |  -4567890123456789.000
 
261
(5 rows)
 
262
 
 
263
SELECT '' AS to_char_14, to_char(q2, 'FM9999999999999999.999') FROM INT8_TBL;
 
264
 to_char_14 |      to_char       
 
265
------------+--------------------
 
266
            | 456.
 
267
            | 4567890123456789.
 
268
            | 123.
 
269
            | 4567890123456789.
 
270
            | -4567890123456789.
 
271
(5 rows)
 
272
 
 
273
SELECT '' AS to_char_15, to_char(q2, 'S 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 . 9 9 9') FROM INT8_TBL;
 
274
 to_char_15 |                  to_char                  
 
275
------------+-------------------------------------------
 
276
            |                            +4 5 6 . 0 0 0
 
277
            |  +4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 . 0 0 0
 
278
            |                            +1 2 3 . 0 0 0
 
279
            |  +4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 . 0 0 0
 
280
            |  -4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 . 0 0 0
 
281
(5 rows)
 
282
 
 
283
SELECT '' AS to_char_16, to_char(q2, '99999 "text" 9999 "9999" 999 "\\"text between quote marks\\"" 9999') FROM INT8_TBL;
 
284
 to_char_16 |                          to_char                          
 
285
------------+-----------------------------------------------------------
 
286
            |       text      9999     "text between quote marks"   456
 
287
            |  45678 text 9012 9999 345 "text between quote marks" 6789
 
288
            |       text      9999     "text between quote marks"   123
 
289
            |  45678 text 9012 9999 345 "text between quote marks" 6789
 
290
            | -45678 text 9012 9999 345 "text between quote marks" 6789
 
291
(5 rows)
 
292
 
 
293
SELECT '' AS to_char_17, to_char(q2, '999999SG9999999999')     FROM INT8_TBL;
 
294
 to_char_17 |      to_char      
 
295
------------+-------------------
 
296
            |       +       456
 
297
            | 456789+0123456789
 
298
            |       +       123
 
299
            | 456789+0123456789
 
300
            | 456789-0123456789
 
301
(5 rows)
 
302