字段设计
选择数据类型
在字段设计时,基于查询效率的考虑,一般遵循以下原则:
【建议】尽量使用高效数据类型。
选择数值类型时,在满足业务精度的情况下,选择数据类型的优先级从高到低依次为整数、浮点数、NUMERIC。
【建议】当多个表存在逻辑关系时,表示同一含义的字段应该使用相同的数据类型。
【建议】对于字符串数据,建议使用变长字符串数据类型,并指定最大长度。请务必确保指定的最大长度大于需要存储的最大字符数,避免超出最大长度时出现字符截断现象。除非明确知道数据类型为固定长度字符串,否则,不建议使用CHAR(n)、BPCHAR(n)、NCHAR(n)、CHARACTER(n)。
关于字符串类型的详细说明,请参见常用字符串类型介绍。
常用字符串类型介绍
在进行字段设计时,需要根据数据特征选择相应的数据类型。字符串类型在使用时比较容易混淆,下表列出了openGauss中常见的字符串类型:
表 1 常用字符串类型
名称 | 描述 | 最大存储空间 |
---|
CHAR(n) | 定长字符串,n描述了存储的字节长度,如果输入的字符串字节格式小于n,那么后面会自动用空字符补齐至n个字节。 | 10MB |
CHARACTER(n) | 定长字符串,n描述了存储的字节长度,如果输入的字符串字节格式小于n,那么后面会自动用空字符补齐至n个字节。 | 10MB |
NCHAR(n) | 定长字符串,n描述了存储的字节长度,如果输入的字符串字节格式小于n,那么后面会自动用空字符补齐至n个字节。 | 10MB |
BPCHAR(n) | 定长字符串,n描述了存储的字节长度,如果输入的字符串字节格式小于n,那么后面会自动用空字符补齐至n个字节。 | 10MB |
VARCHAR(n) | 变长字符串,n描述了可以存储的最大字节长度。 | 10MB |
CHARACTER VARYING(n) | 变长字符串,n描述了可以存储的最大字节长度;此数据类型和VARCHAR(n)是同一数据类型的不同表达形式。 | 10MB |
VARCHAR2(n) | 变长字符串,n描述了可以存储的最大字节长度,此数据类型是为兼容Oracle类型新增的,行为和VARCHAR(n)一致。 | 10MB |
NVARCHAR2(n) | 变长字符串,n描述了可以存储的最大字节长度。 | 10MB |
TEXT | 不限长度(不超过1GB-8203字节)变长字符串。 | 1GB-8203字节 |