CREATE TABLE test (c varchar(5));
現在開始插入資料庫,每次增加一個長度
test=> INSERT INTO test VALUES ('1');
INSERT 0 1
test=> INSERT INTO test VALUES ('12');
INSERT 0 1
test=> INSERT INTO test VALUES ('123');
INSERT 0 1
test=> INSERT INTO test VALUES ('1234');
INSERT 0 1
test=> INSERT INTO test VALUES ('12345');
INSERT 0 1
test=> INSERT INTO test VALUES ('123456');
ERROR: value too long for type character varying(5)
test=> INSERT INTO test VALUES ('1234567');
ERROR: value too long for type character varying(5)
test=>
超出長度會提示 ERROR: value too long for type character varying(5)
通過 ::varchar(5) 截取5前五個字元,後面拋棄
test=> INSERT INTO test VALUES ('123456'::varchar(5));
INSERT 0 1
test=> INSERT INTO test VALUES ('1234567'::varchar(5));
INSERT 0 1
test=> INSERT INTO test VALUES ('12345678'::varchar(5));
INSERT 0 1
超過的部分被自動截取
test=> select * from test; c ------- 1 12 123 1234 12345 12345 12345 12345 (8 rows)