无论是在小得可怜的免费数据库空间或是大型电子商务网站,合理的设计表结构、充分利用空间是十分必要的。这就要求我们对数据库系统的常用数据类型有充分的认识。下面我就将我的一点心得写出来跟大家分享。
一、数字类型
数字类型按照我的分类方法分为三类:整数类、小数类和数字类。
我所谓的“数字类”,就是指DECIMAL和NUMERIC,它们是同一种类型。它严格的说不是一种数字类型,因为他们实际上是将数字以字符串形式保存的;他的值的每一位(包括小数点)占一个字节的存储空间,因此这种类型耗费空间比较大。但是它的一个突出的优点是小数的位数固定,在运算中不会“失真”,所以比较适合用于“价格”、“金额”这样对精度要求不高但准确度要求非常高的字段。
小数类,即浮点数类型,根据精度的不同,有FLOAT和DOUBLE两种。它们的优势是精确度,FLOAT可以表示绝对值非常小、小到约1.17E-38(0.000...0117,小数点后面有37个零)的小数,而DOUBLE更是可以表示绝对值小到约2.22E-308(0.000...0222,小数点后面有307个零)的小数。FLOAT类型和DOUBLE类型占用存储空间分别是4字节和8字节。如果需要用到小数的字段,精度要求不高的,当然用FLOAT了。可是说句实在话,我们“民用”的数据,哪有要求精度那么高的呢?这两种类型至今我没有用过――我还没有遇到适合于使用它们的事例。
用的最多的,最值得精打细算的,是整数类型。从只占一个字节存储空间的TINYINT到占8个字节的BIGINT,挑选一个“够用”并且占用存储空间最小的类型是设计数据库时应该考虑的。TINYINT、SMALLINT、MEDIUMINT、INT和BIGINT占用存储空间分别为1字节、2字节、3字节、4字节和8字节,就无符号的整数而言,这些类型能表示的最大整数分别为255、65535、16777215、4294967295和18446744073709551615。如果用来保存用户的年龄(举例来说,数据库中保存年龄是不可取的),用TINYINT就够了;九城的《纵横》里,各项技能值,用SMALLINT也够了;如果要用作一个肯定不会超过16000000行的表的AUTO_INCREMENT的IDENTIFY字段,当然用MEDIUMINT不用INT,试想,每行节约一个字节,16000000行可以节约10兆多呢!
二、日期时间类型
日期和时间类型比较简单,无非是DATE、TIME、DATETIME、TIMESTAMP和YEAR等几个类型。只对日期敏感,而对时间没有要求的字段,就用DATE而不用DATETIME是不用说的了;单独使用时间的情况也时有发生――使用TIME;但最多用到的还是用DATETIME。在日期时间类型上没有什么文章可做,这里就不再详述。
三、字符(串)类型
不要以为字符类型就是CHAR,CHAR和VARCHAR的区别在于CHAR是固定长度,只要你定义一个字段是CHAR(10),那么不论你存储的数据是否达到了10个字节,它都要占去10个字节的空间;而VARCHAR则是可变长度的,如果一个字段可能的值是不固定长度的,我们只知道它不可能超过10个字符,把它定义为VARCHAR(10)是最合算的,VARCHAR类型的占用空间是它的值的实际长度+1。为什么要+1呢?这一个字节用于保存实际使用了多大的长度。从这个+1中也应该看到,如果一个字段,它的可能值最长是10个字符,而多数情况下也就是用到了10个字符时,用VARCHAR就不合算了:因为在多数情况下,实际占用空间是11个字节,比用CHAR(10)还多占用一个字节。
举个例子,就是一个存储股票名称和代码的表,股票名称绝大部分是四个字的,即8个字节;股票代码,上海的是六位数字,深圳的是四位数字。这些都是固定长度的,股票名称当然要用CHAR(8);股票代码虽然是不固定长度,但如果使用VARCHAR(6),一个深圳的股票代码实际占用空间是5个字节,而一个上海的股票代码要占用7个字节!考虑到上海的股票数目比深圳的多,那么用VARCHAR(6)就不如CHAR(6)合算了。
虽然一个CHAR或VARCHAR的最大长度可以到255,我认为大于20的CHAR是几乎用不到的――很少有大于20个字节长度的固定长度的东东吧?不是固定长度的就用VARCHAR。大于100的VARCHAR也是几乎用不到的――比这更大的用TEXT就好了。TINYTEXT,最大长度为255,占用空间也是实际长度+1;TEXT,最大长度65535,占用空间是实际长度+2;MEDIUMTEXT,最大长度16777215,占用空间是实际长度+3;LONGTEXT,最大长度4294967295,占用空间是实际长度+4。为什么+1、+2、+3、+4?你要是还不知道就该打PP了。这些可以用在论坛啊、新闻啊,什么的,用来保存文章的正文。根据实际情况的不同,选择从小到大的不同类型。
四、枚举和集合类型
枚举(ENUM)类型,最多可以定义65535种不同的字符串从中做出选择,只能并且必须选择其中一种,占用存储空间是一个或两个字节,由枚举值的数目决定;集合(SET)类型,最多可以有64个成员,可以选择其中的零个到不限定的多个,占用存储空间是一个到八个字节,由集合可能的成员数目决定。
举个例子来说,在SQL Server中,你可以节约到用一个BIT类型来表示性别(男/女),但MySQL没有BIT,用TINTINT吗?不,可以用ENUM(’帅哥’,’美眉’),只有两种选择,所以只需一个字节――跟TINYINT一样大,但却可以直接用字符串’帅哥’和’美眉’来存取。真是太方便啦!
分享到:
相关推荐
MySQL 数据类型和建库策略是数据库设计中的关键环节,它直接影响到数据的存储效率和准确性。下面我们将深入探讨这些知识点。 首先,数字类型是数据库中常见的数据类型,分为整数类、小数类和数字类。整数类包括...
本教程将深入探讨MySQL中的数据类型和建库策略,这对于任何想要优化数据库性能和确保数据准确性的开发者来说都是至关重要的。 首先,我们来谈谈MySQL的数据类型。数据类型决定了存储在数据库中的数据的格式和类型。...
MySQL数据库系统是世界上最受...总之,理解MySQL的数据类型和建库策略对于有效管理和利用数据至关重要。在设计数据库时,应充分考虑业务需求、数据特性和性能要求,做出最佳决策,以确保数据的准确性和系统的高效运行。
在设计和管理MySQL数据库时,了解其数据类型和建库策略至关重要。 首先,MySQL提供了多种数据类型,这些数据类型大致可以分为以下几类: 1. 整数类:包括TINYINT、SMALLINT、MEDIUMINT、INT(INTEGER)和BIGINT。...
MySQL 数据类型和建库策略是数据库设计中的关键环节,对于优化存储空间和提高效率至关重要。在设计数据库表结构时,选择合适的字段类型对于节省存储空间、提升查询速度以及确保数据准确性都有直接影响。 1. 数字...
以下是关于MySQL数据类型的一些详细解释: 1. **数字类型** - **整数类**:包括TINYINT、SMALLINT、MEDIUMINT、INT和BIGINT,它们分别占用1、2、3、4和8个字节的存储空间。无符号整数的最大值分别为255、65535、...
MySQL 数据类型和建库策略是数据库设计中的关键因素,它们直接影响到数据的存储效率和准确性。数据类型的选择决定了数据在数据库中的存储方式和占用的空间,而建库策略则关乎到数据库的整体性能和扩展性。 首先,...
MySQL 数据类型和建库策略是数据库设计中的关键因素,它们直接影响到数据的存储效率、查询性能以及整体数据库的稳定性。以下是对这些知识点的详细解析: 首先,数字类型是数据库中最常见的数据类型之一,主要包括...
4.MySQL的数据类型和建库策略详解 5.MySQL多表操作和备份处理 6.MySQL索引分类和各自用途 7.MySQL中的字符串比较函数 8.MySQL中字符串函数详细介绍 9.都出深入SELECT语句的查询功能 10.浅谈MySQL存储引擎选择InnoDB...
mysql.chm-----01_MySQL常用命令.ppt 01_MySQL常用命令.ppt------MySQL常用数据类型和建库策略.doc-----CRJ-2_1AA.pps------CRJ-2_1B.pps ---TXT
8. **安全策略**:定期更新MySQL版本,设置强壮的密码策略,限制不必要的网络访问,以及使用SSL加密连接等,确保数据安全。 9. **故障排查**:学习如何识别和解决常见的错误和性能问题,如死锁、内存不足、慢查询等...
9. **数据库设计**:MySQL数据库的建库策略包括表结构设计、索引优化、数据类型选择等,以确保数据的高效存储和快速查询。 10. **编码与测试**:系统开发完成后,需要进行编码实现,并进行单元测试、集成测试和系统...
在构建MySQL数据库时,合理的设计和优化是至关重要的。本文主要分享了四个关于数据库建库建表的实用技巧,旨在帮助提升数据库性能和维护性。 首先,关于表间关联,作者建议避免直接使用主键进行关联。以新闻栏目表...
1.2.6 创建存放两个 mysql 实例的数据目录...............................................................11 1.2.7 创建两个 mysql 多实例的配置文件.............................................................
在创建时,我们需要确保表的字段类型与数据一致,例如admin_id可能是整数类型,username和password可能是字符串类型。 接下来是Class表,它可能包含班级ID(class_id)、班级名称(class_name)等字段,用于记录...
1. **数据库类型选择**:科脉系统可能基于关系型数据库,如MySQL、SQL Server或Oracle,这些数据库能够处理大量结构化数据并支持复杂的查询操作。 2. **数据库安装**:这包括下载合适的数据库服务器软件,按照官方...
记录数据集的基本信息,包括数据集ID、名称、描述、数据类型等。 ##### 4.4 MapDefine地图信息表 保存地图的基本属性,如地图ID、名称、比例尺范围、中心点坐标等。 ##### 4.5 LAYERDEFINE图层信息表 描述地图中各...