怎样模仿别人的网站手机网站有什么要求
Schema设计原则 :
- 更小的数据类型,根据估计选择不会超过范围的最小数据类型。
- 简单数据类型的操作通常需要更少的CPU周期。例如整型比字符操作代价更低,因为字符集和校对规则(排序规则)使字符比较比整型比较更复杂。
尽量避免NULL:最好指定列为NOT NULL,除非真的需要存储NULL值。NULL列使得索引、索引统计和值比较都更复杂,使用更多的存储空间。如果计划在列上建索引,就应该尽量避免设计成可为NULL的列
实数类型
- FLOAT 和 DOUBLE类型支持使用标准的浮点运算进行近似计算。DECIMAL类型用于存储精确的小数。
- CPU直接支持原生浮点计算,所以浮点运算明显更快。
因为需要额外的空间和计算开销,所以尽量只在对小数进行精确计算时才使用DECIMAL—例如存储财务数据。但在数据量比较大的时候,可以考虑使用BIGINT代替DECIMAL,将需要存储的数值根据小数的位数乘以相应倍数即可
字符串类型
下面这些情况使用VARCHAR:
- 字符串列的最大长度比平均长度大很多;
- 列的更新很少,所以碎片不是问题;
- 使用了像UTF-8这样复杂的字符集,每个字符都使用不同的字节数进行存储
CAHR的使用场景:
- CHAR类型是定长的,适合存储很短的字符串,或所有值接近同一个长度;
枚举类型
- 把一些不重复的字符串存储成一个预定义的集合。MySQL在存储枚举时非常紧凑,会根据列表值的数量压缩到一个或者两个字节中。
- 枚举最不好的地方是,字符串列表是固定的,添加或删除字符串必须使用ALTER TABLE,因此对于未来可变的字符串,不建议使用枚举。
特殊数据类型
IPv4 地址:虽然经常使用VARCHAR(15)列来存储IP地址。然而,它们实际上是32位无符号整数,不是字符串。用小数点将地址分成四段的表示方法只是为了让人们阅读容易。所以应该用无符号整数存储IP地址。MySQL提供INET_ATON() 和 INET_NTOA()函数在这两种表示方法之间转换。用varchar存储ip地址的弊端之一是:无法根据指定的ip地址范围进行区间搜索,而转换为32位无符号整数则可以