zoukankan      html  css  js  c++  java
  • 四、MYSQL的数据类型

    类型选择原则

    1、储存空间越少越好;

    2、简单就好:例如整型比字符串更简单;

    3、尽量避免null;

    一、整数类型

      1、有tinyint(8位)、SMALLINT(16位)、MEDIUMINT(24位)、int(32位)、bigint(64位) 这5种;

      2、使用unsigned(无符号)能提升一倍的范围;

      3、MYSQL能为整型类型指定宽度,例如int(11),不过这不影响计算和储存,int(11)和int(20)是一样的;只是规定mysql一些客户端显示字符的个数;

    二、实数类型(浮点)

      

    三、字符串类型

      1、varchar:可变字符串长度,需要额外的储存空间保存字段长度,例如varchar(10)则需要11个字节的长度作为储存空间。更新的时候会产生碎片

        适合的使用场景:最长的长度比一般的长度大的多,平时很少修改;INNODB引擎会把过长的varchar变为BLOB;

      2、char:定长字符串,适合放MD5值等固定长度的字段,而且同样是char(10)和varchar(10),前者比后者少一个字节(varchar10需要11个字节);

      

       3、blob(二进制)和text(有字符集的类型)类型:两者都是

       4、enum枚举类型(以后再看

    四、时间类型

      一般的时间类型都是没有代替品的,唯一可能接近混淆的是datetime和timestamp

    五、范式化与反范式化

      范式化-为了更省磁盘空间,更新时候涉及的磁盘位置更少,但是牺牲了查询速度;

      反范式化-牺牲更多的磁盘空间,但是换来了查询的速度;

  • 相关阅读:
    c++ fstream中seekg()和seekp()的用法
    java连接MySql数据库
    AspNetPager查询分页问题(点击页码,不再是查询后的数据集)viewstate解决
    C#操作XML文档
    关于PHP程序员解决问题的能力
    HDOJ 1874( dijkstra )
    错排问题 (Mathematics)
    中缀表达式到后缀表达式 (Data_Structure)
    几次到1(分治递归)
    max(int) = 0x7fffffff
  • 原文地址:https://www.cnblogs.com/yeyongjian/p/9407435.html
Copyright © 2011-2022 走看看