`
爱像天空
  • 浏览: 204662 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

MySQL数据类型与建库策略的剖析

阅读更多
此文章主要描述的是MySQL数据类型与建库策略的详细解析,我们大家都知道无论是在不收费的数据库空间或者是大型的电子商务网站,其合理的设计表结构、充分利用空间是十分必要的。

这就要求我们对数据库系统的常用MySQL数据类型有充分的认识。下面我就将我的一点心得写出来跟大家分享。

一、MySQL数据类型之数字类型

数字类型按照我的分类方法分为三类:整数类、小数类和数字类。

我所谓的“数字类”,就是指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(WINDOWS平台上强大的数据库平台)中,你可以节约到用一个BIT类型来表示性别(男/女),但MySQL(和PHP搭配之最佳组合)没有BIT,用TINTINT吗?不,可以用ENUM(’帅哥’,’美眉’),只有两种选择,所以只需一个字节――跟TINYINT一样大,但却可以直接用字符串’帅哥’和’美眉’来存取。真是太方便啦!

好了,MySQL(和PHP搭配之最佳组合)的MySQL数据类型介绍得差不多,我的建库策略也随着介绍MySQL数据类型介绍给大家一些。但这只是其中一部分,篇幅有限,不能再细说;其他的,就靠各人在对数据类型理解的基础上,多多实践、多多讨论。
分享到:
评论

相关推荐

    分析MySQL的数据类型以及建库策略

    本文将深入分析MySQL中的主要数据类型,并探讨如何根据实际需求来选择合适的数据类型。 首先,我们来看数字类型。MySQL中的数字类型主要包括整数类、小数类和数字类。整数类包括TINYINT、SMALLINT、MEDIUMINT、INT...

    MySQL的数据类型和建库策略分析详解

    MySQL 数据类型和建库策略是数据库设计中的关键因素,它们直接影响到数据的存储效率、查询性能以及整体数据库的稳定性。以下是对这些知识点的详细解析: 首先,数字类型是数据库中最常见的数据类型之一,主要包括...

    mysql可视化工具建库模式.png

    【标题】:“MySQL 可视化工具建库模式”指的是使用图形用户界面(GUI)工具来创建和管理 MySQL 数据库的模式,这种工具通常提供直观的界面,使得数据库的建立和操作过程更为简单易懂,尤其对于初学者来说非常友好。...

    mysql英文单词库

    `words.sql` 文件很可能是数据库的备份或导出,包含了创建和填充这些表的SQL语句,可以导入到MySQL环境中恢复数据。而`read.txt`可能是关于如何使用这些数据或数据库的说明文档。 总结来说,MySQL英文单词库是一个...

    基于Python脚本的建设用地报批数据建库.zip

    6. **数据建模**:在建库前,需要定义数据库模式,包括表的结构、字段类型、键的设置等。这一步可能涉及理解业务逻辑,将现实世界的实体转化为数据库模型。 7. **数据清洗**:建设用地报批数据可能存在缺失值、异常...

    数据库系统概念建库文件.zip

    2. **数据类型**:每个字段都有其特定的数据类型,如整数(INT)、浮点数(FLOAT)、字符串(VARCHAR)、日期/时间(DATE、TIME、DATETIME)等,选择合适的数据类型能有效节省存储空间并提高查询效率。 3. **约束**...

    Mysql 建库建表技巧分享

    在MySQL数据库设计中,建库建表的技巧至关重要,它们直接影响到数据库的稳定性和效率。以下根据标题和描述,结合部分内容,将分享一些关键的知识点: 1. **避免使用主键进行关联**: 在创建关联表时,不推荐直接...

    python数据分析与挖掘实战-第2章 数据获取.zip

    在Python数据分析与挖掘实战的第二章中,我们主要探讨的是数据获取这一关键步骤。数据是所有分析的基础,没有数据就无法进行有效的分析和挖掘。这一章涵盖了如何从各种来源获取数据,包括网络爬虫、数据库连接、API...

    mysql代码-建库建表语句

    在MySQL数据库管理系统中,创建数据库和表格是进行数据存储与管理的基础操作。下面将详细讲解如何使用SQL语句来执行这些任务。 首先,我们来看创建数据库的语句。在MySQL中,`CREATE DATABASE` 语句用于新建一个...

    毕业论文jsp726合同管理系统mysql.doc

    9. **数据库设计**:MySQL数据库的建库策略包括表结构设计、索引优化、数据类型选择等,以确保数据的高效存储和快速查询。 10. **编码与测试**:系统开发完成后,需要进行编码实现,并进行单元测试、集成测试和系统...

    j2ee宠物店建库语句

    2. **数据类型**:SQL支持多种数据类型,如数值型(INT、FLOAT、DOUBLE等)、字符串型(VARCHAR、CHAR)、日期/时间型(DATE、TIME、TIMESTAMP)等。 3. **索引**:为了提高查询性能,常常会在表的某些字段上创建...

    MySql5.0命令全集.pdf

    包括更改密码、显示数据库列表、显示表结构、建库、建表、删除数据库或表、插入数据、查询数据、更新数据、清空表、增加字段、更改字段名称、默认值、数据类型、增加主键、导入SQL文件、导入文本文件、备份数据库、...

    MySQLDBA运维笔记.pdf

    1.2.6 创建存放两个 mysql 实例的数据目录...............................................................11 1.2.7 创建两个 mysql 多实例的配置文件.............................................................

    mysql总结超详细

    3. **列族存储**:如Cassandra,适合大数据分析和分布式存储场景。 4. **图形数据库**:如Neo4j,用于处理具有复杂关系的数据集。 ##### 1.1.4 关系型数据库产品介绍 关系型数据库产品主要包括: - **MySQL**:...

    科脉3.0第二步DB_setup(数据库)(官方原版).zip

    1. **数据库类型选择**:科脉系统可能基于关系型数据库,如MySQL、SQL Server或Oracle,这些数据库能够处理大量结构化数据并支持复杂的查询操作。 2. **数据库安装**:这包括下载合适的数据库服务器软件,按照官方...

    多源空间数据综合管理平台总体设计20130329

    记录数据集的基本信息,包括数据集ID、名称、描述、数据类型等。 ##### 4.4 MapDefine地图信息表 保存地图的基本属性,如地图ID、名称、比例尺范围、中心点坐标等。 ##### 4.5 LAYERDEFINE图层信息表 描述地图中各...

    2018211302-胡天翼、陆佳纬、熊宇-数据库系统原理实验报告1

    本实验报告主要涵盖了数据库系统的基础操作,包括建表建库、数据查询与修改、完整性约束、数据接口以及事务管理。实验使用了GaussDB(for MySQL)数据库管理系统,并借助华为云数据管理服务(DAS)和MySQL Workbench...

    图书馆管理系统需求分析.docx

    - **数据统计**:生成各类数据分析报告,帮助图书馆优化资源分配和服务策略。 - **图书检索**:通过关键词、作者等信息快速定位图书位置,提高找书效率。 - **图书预借**:允许读者在线预约未上架的新书,提高图书...

    数据库物流管理

    在物流管理中,常见的数据库类型包括关系型数据库(如MySQL、Oracle)和非关系型数据库(如MongoDB、Cassandra)。关系型数据库通常用于结构化数据,如订单信息,而非关系型数据库则适合处理半结构化或非结构化的...

Global site tag (gtag.js) - Google Analytics