8.3. 字符类型
Table 8-4. 字符类型
名字 描述
character varying(n), varchar(n) 变长,有长度限制
character(n), char(n) 定长,不足补空白
text 变长,无长度限制
Table 8-4 显示了在 PostgreSQL 里可用的一般用途的字符类型。
SQL 定义了两种基本的字符类型: character varying(n) 和 character(n), 这里的 n 是一个正整数。两种类型都可以存储最多 n 个字符长的字串。 试图存储更长的字串到这些类型的字段里会产生一个错误, 除非超出长度的字符都是空白,这种情况下该字串将被截断为最大长度。 (这个看上去有点怪异的例外是SQL标准要求的。) 如果要存储的字串比声明的长度短, 类型为 character 的数值将会用空白填满; 而类型为 character varying 的数值将只是存储短些的字串。
如果我们明确地把一个数值转换成 character(n) 或者 character varying(n), 那么超长的数值将被截断成 n 个字符,而不会抛出错误。(这也是SQL标准的要求。)
注意: 在PostgreSQL7.2 以前,太长的字串总会被不声不响地咔喳掉, 而且不会生成错误。不管是明确的还是隐含的转换情况下。