数据库表结构创建与管理:SQL 实战指南
1. 数据类型选择
数据类型的选择有时需要专业判断。以 V_CODE 为例,有以下两种情况:
- 若希望计算机通过在最大记录的供应商代码上加 1 来生成新的供应商代码,需将 V_CODE 归类为数值属性。因为不能对字符数据执行数学运算,使用 INTEGER 可确保仅能使用计数数字(整数)。大多数 SQL 实现也允许对最多六位的整数值使用 SMALLINT 。
- 若不想基于 V_CODE 执行数学运算,即使它完全由数字组成,也应将其归类为字符属性。当无需对该属性执行数学运算时,将其存储为字符属性。
在定义属性的数据类型时,必须密切关注属性用于排序和数据检索的预期用途。例如,在房地产应用中,代表房屋卫生间数量的属性 H_BATH_NUM 可分配 CHAR(3) 数据类型,因为该应用可能不会对卫生间数量进行加法、乘法或除法运算。基于 CHAR(3) 数据类型定义,有效的 H_BATH_NUM 值可以是 '2' 、 '1' 、 '2.5' 、 '10' 。但这种数据类型决策会产生潜在问题,如按卫生间数量对房屋进行排序时,查询会将值 '10' 视为小于 '2' ,这显然是不正确的。所以,必须考虑数据的预期
超级会员免费看
订阅专栏 解锁全文
2614

被折叠的 条评论
为什么被折叠?



