**太多的列**
mysql的存储引擎API工作时需要在服务器层和存储引擎层之间通过行缓存格式拷贝数据,然后在服务层将缓存内容解码成各个列.从行缓冲中将编码过的列转换成行数据结构的操作代价是非常高的
myisam的定长行结构实际上与服务层的行结构正好匹配,所以不需要转换.然而myisam的变长行结构和Innodb的行结构则总是需要转换.转换的代价依赖于列的数量
**太多的关联**
所谓的"实体-属性-值"(ENV)设计模式是一个常见的糟糕设计模式,尤其在mysql下不能靠谱的工作.mysql限制了每个关联操作最多只能有61张表,但是ENV数据库需要很多自关联.
事实上在许多关联少于61张表的情况下,解析和优化查询的代价也会成为mysql的问题
**全能的枚举**
注意防止过度使用枚举(ENUM)
~~~
create table ... (
country enum('','0','1','2',...'31')
~~~
这种模式的表设计非常凌乱.这么使用枚举值类型也会在任何支持枚举类型的数据库都是一个有问题的设计方案,这里应该用整数作为外键关联到字典表或者查找表来查找具体值
但是在mysql中,当需要在枚举列表中增加一个新的国家时就要做一次ALTER TABLE操作,在mysql5.0以及更早的版本中ALTER TABLE是一个阻塞操作,即使在5.1和更新的版本中,如果不是在列表的末尾增加值也会一样需要ALTER TABLE
**变相的枚举**
枚举(ENUM)列允许在列中存储一组定义值中的单个值,集合(SET)列则允许在列中存储一组定义值中的一个或多个值.有时候这可能比较容易导致混乱.这是一个例子
~~~
create table ... (
is_default set('Y', 'N') NOT NULL default 'N'
~~~
如果这里真和假两种情况不会同时出现,那么毫无疑问应该使用枚举列代替集合列
**非此发明的NULL**
写了避免使用NULL的好处,并且建议尽可能考虑替代方案
即使需要存储一个事实上的"空值"到表中,也不一定非得使用NULL.也许可以使用0,某个特殊值,或者空字符串作为代替
但是遵循这个原则也不要走极端.当确实需要表示未知值时也不要害怕使用null,在一些场景中,使用null可能会比某个神奇常数更好.从特定类型的值域中选择一个不可能的值.例如使用-1代表一个未知的整数,可能导致代码复杂很多,并容易引入bug,还可能会让事情变得一团糟.处理null确实不容易,但有时候会比他的替代方案更好
下面是我们经常看到的例子
~~~
create table .. (
dt datetime not null default '0000-00-00 00:00:00'
~~~
伪造的全0值可能导致很多问题(可以配置mysql的sql_mode来禁止不可能的日期,对于新应用这是个非常好的实践经验,它不会让创建的数据库里充满不可能的值).值得一提的是,mysql会在索引中存储NULL值,而Oracle则不会
- 书列表
- laravel框架关键技术
- 第一章 组件化开发与composer使用
- 简介
- composer
- 添加路由组件
- 添加控制器模块
- 添加模型组件
- 添加视图组件
- 第三章 laravel框架中常用的php语法
- 匿名函数
- 文件包含
- 魔术方法
- 魔术常量
- 反射
- 后期静态绑定
- traits
- 第四章 laravel框架中使用的HTTP协议基础
- HTTP协议
- 数据库
- 数据迁移
- 第六章 laravel框架中的设计模式
- IOC模式
- php核心技术与最佳实践
- 第一章面向对象核心
- 反射
- 简单ORM
- 异常和错误
- 接口
- 第二章,面向对象设计
- 设计原则
- 单一职责
- 接口隔离
- 开放封闭
- 替换原则
- 依赖倒置
- linux是怎么写的呢?
- 第三章 正则表达
- 认识正则
- 第四章 php网络技术应用
- HTTP协议详解
- php和http相关函数
- 垃圾信息防御措施
- 现代操作系统
- 引论
- sql必知必会
- 限制结果
- 按位置排序
- where求职顺序
- IN操作符
- like
- 函数
- group by
- 组合查询
- 插入检索出的数据
- 视图
- 高性能mysql
- 第一章节 mysql架构与历史
- mysql架构逻辑图
- 连接与管理
- 优化与运行
- 读写锁
- 锁粒度
- 表锁(table lock)
- 行级锁(row lock)
- ACID
- 隔离级别
- 死锁
- 隐式和显式锁定
- 多版本并发控制
- Innodb概览
- 第四章节 Schema与数据类型优化
- 选择优化的数据类型
- 日期和时间类型
- 标识列
- 特殊类型数据
- 表设计中的缺陷
- 范式
- 计数器表
- 第五章 创建高性能索引
- 索引基础
- 索引类型
- 索引的优点
- 高性能索引策略
- 选择合适的索引列顺序
- 聚簇索引
- 顺序的主键什么时候会造成更坏的后果
- 覆盖索引
- 使用索引扫描来做排序
- 压缩索引
- 冗余和重复索引
- 索引和锁
- 支持多种过滤条件
- 什么是范围条件
- 优化排序
- 维护索引和表
- 表损坏
- 减少索引和数据的碎片
- 第六章 查询性能优化
- 扫描的行数和访问类型
- 重构查询方式
- 查询执行的基础
- 重构-改善既有代码设计
- 第一章-重构
- 什么是重构
- 第一个案列
- 重构第一步
- 王垠博客
- 多态取代价格相关逻辑