您的位置:寻梦网首页编程乐园数据库PostgreSQL 7.2 Documentation

3.3. 字符类型

Table 3-4. 字符类型

类型名 描述
character( n ) , char( n ) 定长,不足补空白
character varying( n ) , varchar( n ) 变长,有长度限制
text 变长,无长度限制

SQL 定义了两种基本的字符类型∶ character( n ) character varying( n ) , 这里的 n 是一个正整数.两种类型都可以存储 最多 n 个字符长的字串. 试图存储更长的字串到这些类型的字段里会产生一个错误, 除非超出长度的字符都是空白,这种情况下该字串将被截断为最大 长度.(这个看上去有点怪异的例外是 SQL 标准要求的.) 如果要存储的字串比声明的长度短, 类型为 character 的数值将会用空白填满; 而类型为 character varying 的数值将只是 存储短些的字串.

注意: PostgreSQL 7.2 以前,太长的字串会被不声不响地咔喳掉, 而且不会生成错误.

char( n ) varchar( n ) 的概念分别是 character( n ) character varying( n ) 的别名, 没有长度声明词的 character 等于 character(1) ;如果不带长度说明词使用 character varying ,那么该类型接受任何长度的字串. 后者是 PostgreSQL 的扩展.

另外, PostgreSQL 支持更通用的 text 类型,它可以存储任何长度的字串. 和 character varying 不同的是, text 不需要明确地声明字串尺寸的上限.尽管类型 text 不是 SQL 标准,但是许多其它 RDBMS 包也有它.

请参考 Section 1.1.2.1 获取关于字串文本 的语法的信息,以及参阅 Chapter 4 获取关于 可用操作符和函数的信息.

这些类型的存储需求是 4 字节加上实际的字串,如果是 character 的话再加上填充的字节.长的字串将会自动被系统压缩,因此在磁盘上的 物理需求可能会更少些.不管怎样,允许存储的最长字串大概是 1 GB. (允许在数据类型声明中出现的的 n 的最大值比这还小. 修改这个行为没有甚么意义,因为在多字节编码下字符和字节的数目可能差别 很大.如果你想存储没有特定上限的长字串,那么使用 text 或者没有长度声明词的 character varying , 而不要选择一个任意长度限制.)

提示: 这三种类型之间没有性能差别,只不过是在使用填充空白的类型的时候 增加了存储尺寸.

Example 3-1. 使用字符类型

CREATE TABLE test1 (a character(4));
INSERT INTO test1 VALUES ('ok');
SELECT a, char_length(a) FROM test1; -- 

(1)



  a   | char_length
------+-------------
 ok   |           4


CREATE TABLE test2 (b varchar(5));
INSERT INTO test2 VALUES ('ok');
INSERT INTO test2 VALUES ('good      ');
INSERT INTO test2 VALUES ('too long');

ERROR:  value too long for type character varying(5)

ELECT b, char_length(b) FROM test2;

   b   | char_length
-------+-------------
 ok    |           2
 good  |           5
(1)
函数 char_length Section 4.4 中讨论.

PostgreSQL 里 另外还有两种定长字符类型. name 类型 用于内部表名字 并且不是给一般用户使用的. 该类型长度当前定为32 字节 (31 可用字符加结束符) 但可以使用宏 NAMEDATALEN 重新定义.这个(变量)是在编译的时候设置的, (因而可以为特殊用途调整); 缺省的最大长度在以后的版本可能会改变. 类型 "char" (注意引号)和 char(1) 是不一样的,它只用了一个字节的存储空间.它在系统内部用于系统表 当做穷人的枚举类型用.

Table 3-5. 特殊字符类型

字符类型 存储空间 描述
"char" 1 字节 单字节内部类型
name 32 字节 三十一字符内部类型