]> granicus.if.org Git - postgresql/blob - src/test/regress/sql/name.sql
Fix initialization of fake LSN for unlogged relations
[postgresql] / src / test / regress / sql / name.sql
1 --
2 -- NAME
3 -- all inputs are silently truncated at NAMEDATALEN-1 (63) characters
4 --
5
6 -- fixed-length by reference
7 SELECT name 'name string' = name 'name string' AS "True";
8
9 SELECT name 'name string' = name 'name string ' AS "False";
10
11 --
12 --
13 --
14
15 CREATE TABLE NAME_TBL(f1 name);
16
17 INSERT INTO NAME_TBL(f1) VALUES ('1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890ABCDEFGHIJKLMNOPQR');
18
19 INSERT INTO NAME_TBL(f1) VALUES ('1234567890abcdefghijklmnopqrstuvwxyz1234567890abcdefghijklmnopqr');
20
21 INSERT INTO NAME_TBL(f1) VALUES ('asdfghjkl;');
22
23 INSERT INTO NAME_TBL(f1) VALUES ('343f%2a');
24
25 INSERT INTO NAME_TBL(f1) VALUES ('d34aaasdf');
26
27 INSERT INTO NAME_TBL(f1) VALUES ('');
28
29 INSERT INTO NAME_TBL(f1) VALUES ('1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ');
30
31
32 SELECT '' AS seven, * FROM NAME_TBL;
33
34 SELECT '' AS six, c.f1 FROM NAME_TBL c WHERE c.f1 <> '1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890ABCDEFGHIJKLMNOPQR';
35
36 SELECT '' AS one, c.f1 FROM NAME_TBL c WHERE c.f1 = '1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890ABCDEFGHIJKLMNOPQR';
37
38 SELECT '' AS three, c.f1 FROM NAME_TBL c WHERE c.f1 < '1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890ABCDEFGHIJKLMNOPQR';
39
40 SELECT '' AS four, c.f1 FROM NAME_TBL c WHERE c.f1 <= '1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890ABCDEFGHIJKLMNOPQR';
41
42 SELECT '' AS three, c.f1 FROM NAME_TBL c WHERE c.f1 > '1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890ABCDEFGHIJKLMNOPQR';
43
44 SELECT '' AS four, c.f1 FROM NAME_TBL c WHERE c.f1 >= '1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890ABCDEFGHIJKLMNOPQR';
45
46 SELECT '' AS seven, c.f1 FROM NAME_TBL c WHERE c.f1 ~ '.*';
47
48 SELECT '' AS zero, c.f1 FROM NAME_TBL c WHERE c.f1 !~ '.*';
49
50 SELECT '' AS three, c.f1 FROM NAME_TBL c WHERE c.f1 ~ '[0-9]';
51
52 SELECT '' AS two, c.f1 FROM NAME_TBL c WHERE c.f1 ~ '.*asdf.*';
53
54 DROP TABLE NAME_TBL;
55
56 DO $$
57 DECLARE r text[];
58 BEGIN
59   r := parse_ident('Schemax.Tabley');
60   RAISE NOTICE '%', format('%I.%I', r[1], r[2]);
61   r := parse_ident('"SchemaX"."TableY"');
62   RAISE NOTICE '%', format('%I.%I', r[1], r[2]);
63 END;
64 $$;
65
66 SELECT parse_ident('foo.boo');
67 SELECT parse_ident('foo.boo[]'); -- should fail
68 SELECT parse_ident('foo.boo[]', strict => false); -- ok
69
70 -- should fail
71 SELECT parse_ident(' ');
72 SELECT parse_ident(' .aaa');
73 SELECT parse_ident(' aaa . ');
74 SELECT parse_ident('aaa.a%b');
75 SELECT parse_ident(E'X\rXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX');
76
77 SELECT length(a[1]), length(a[2]) from parse_ident('"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx".yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy') as a ;
78
79 SELECT parse_ident(' first . "  second  " ."   third   ". "  ' || repeat('x',66) || '"');
80 SELECT parse_ident(' first . "  second  " ."   third   ". "  ' || repeat('x',66) || '"')::name[];
81
82 SELECT parse_ident(E'"c".X XXXX\002XXXXXX');
83 SELECT parse_ident('1020');
84 SELECT parse_ident('10.20');
85 SELECT parse_ident('.');
86 SELECT parse_ident('.1020');
87 SELECT parse_ident('xxx.1020');