mirror of
https://git.postgresql.org/git/postgresql.git
synced 2026-02-24 23:37:03 +08:00
Many older tests where written in a style like
SELECT '' AS two, i.* FROM INT2_TBL
where the first column indicated the number of expected result rows.
This has gotten increasingly out of date, as the test data fixtures
have expanded, so a lot of these were wrong and misleading. Moreover,
this style isn't really necessary, since the psql output already shows
the number of result rows.
To clean this up, remove all those extra columns.
Discussion: https://www.postgresql.org/message-id/flat/1a25312b-2686-380d-3c67-7a69094a999f%40enterprisedb.com
76 lines
1.3 KiB
SQL
76 lines
1.3 KiB
SQL
--
|
|
-- CHAR
|
|
--
|
|
|
|
-- fixed-length by value
|
|
-- internally passed by value if <= 4 bytes in storage
|
|
|
|
SELECT char 'c' = char 'c' AS true;
|
|
|
|
--
|
|
-- Build a table for testing
|
|
--
|
|
|
|
CREATE TABLE CHAR_TBL(f1 char);
|
|
|
|
INSERT INTO CHAR_TBL (f1) VALUES ('a');
|
|
|
|
INSERT INTO CHAR_TBL (f1) VALUES ('A');
|
|
|
|
-- any of the following three input formats are acceptable
|
|
INSERT INTO CHAR_TBL (f1) VALUES ('1');
|
|
|
|
INSERT INTO CHAR_TBL (f1) VALUES (2);
|
|
|
|
INSERT INTO CHAR_TBL (f1) VALUES ('3');
|
|
|
|
-- zero-length char
|
|
INSERT INTO CHAR_TBL (f1) VALUES ('');
|
|
|
|
-- try char's of greater than 1 length
|
|
INSERT INTO CHAR_TBL (f1) VALUES ('cd');
|
|
INSERT INTO CHAR_TBL (f1) VALUES ('c ');
|
|
|
|
|
|
SELECT * FROM CHAR_TBL;
|
|
|
|
SELECT c.*
|
|
FROM CHAR_TBL c
|
|
WHERE c.f1 <> 'a';
|
|
|
|
SELECT c.*
|
|
FROM CHAR_TBL c
|
|
WHERE c.f1 = 'a';
|
|
|
|
SELECT c.*
|
|
FROM CHAR_TBL c
|
|
WHERE c.f1 < 'a';
|
|
|
|
SELECT c.*
|
|
FROM CHAR_TBL c
|
|
WHERE c.f1 <= 'a';
|
|
|
|
SELECT c.*
|
|
FROM CHAR_TBL c
|
|
WHERE c.f1 > 'a';
|
|
|
|
SELECT c.*
|
|
FROM CHAR_TBL c
|
|
WHERE c.f1 >= 'a';
|
|
|
|
DROP TABLE CHAR_TBL;
|
|
|
|
--
|
|
-- Now test longer arrays of char
|
|
--
|
|
|
|
CREATE TABLE CHAR_TBL(f1 char(4));
|
|
|
|
INSERT INTO CHAR_TBL (f1) VALUES ('a');
|
|
INSERT INTO CHAR_TBL (f1) VALUES ('ab');
|
|
INSERT INTO CHAR_TBL (f1) VALUES ('abcd');
|
|
INSERT INTO CHAR_TBL (f1) VALUES ('abcde');
|
|
INSERT INTO CHAR_TBL (f1) VALUES ('abcd ');
|
|
|
|
SELECT * FROM CHAR_TBL;
|