PHP与MySQL学习笔记8:重要概念与设计Web数据库

一、存储引擎
MySQL支持许多不一样的“存储引擎”,也叫做“表格类型”。每一个表但是使用不一样的存储引擎,并且能够轻松地对它们进行转换。
建立表时能够选择一个表格类型:
CREATE TABLE table TYPE = type....
修改表类型:
alter table orders type = innodb;

1)MyISAM,默认类型
它基于传统的ISAM类型,Indexed Sequential Access Method(有索引的顺序访问方法)的缩写,它是存储记录和文件的标准方法。
MyISAM特色:
MyISAM具备检查和修复表格的大多数工具,表格能够被压缩,支持全文搜索。可是它们不是事务安全的,也不支持外键。

2)InnoDB
该类型表是事务安全的,也就是说,它提供了 COMMIT 和 ROLLBACK功能。InnoDB支持外键。 虽然比MyISAM表要慢些,可是若是应用程序须要一个事务安全的存储引擎,建议使用。

注:在大多数Web应用程序中,一般都会使用MyISAM或InnoDB表格或者两者的结合。

3)MEMORY (之前的 HEAP
该类型表,存储在内存中,表的索引是哈希分布的。
MEMORY表格运行速度很是快,可是若是发生崩溃,数据将丢失。
建议:MEMORY表格适合保存临时或者派生的数据,应该在CREATE TABLE语句中指定MAX_ROWS,不然这些表可能吞噬全部内存。一样,它们不能加入BLOB、TEXT或AUTO INCREMENT列。

4)MERGE
这些表容许你为了查询目的,把MyISAM表的集合做为一个单个表。所以,你可在某些操做系统中,避开最大文件大小限制。

5)ARCHIVE
这些表保存了大量数据,可是只有少许脚注(footprint)。这种类型的表只支持INSERT 和SELECT 查询。不支持DELETE、UPDATE 和 REPLACE。此外,也不使用索引。

6)CSV
这些表保存在服务器的单个文件中,它包含用逗号隔离的数据。
能够方便地用Excel等第三方工具打开。

建议:
当对一个表格使用大量的SELECT  和 INSERT 语句(或者两者结合)时,应该使用MyISAM 表格,由于在执行这两种命令时,MyISAM是最快的。对于不少Web程序(例如分类)来讲,MyISAM是最佳选择。若是须要全文搜索功能,也应该使用MyISAM功能。
当事务很是重要(例如存储财务数据),或在INSERT 和 SELECT 语句是交错执行的状况下(例如在线的消息栏或论坛系统),应该使用 InnoDB。InnoDB在MySQL5.6版本中好像支持全文索引了。

二、事务
事务是确保数据库一致的机制,尤为是在发生错误或服务器崩溃状况下确保数据库一致的机制。
事务是一个或一系列的查询,这些查询能够保证可以在数据库中做为一个总体所有执行或者所有不执行。这样,数据库才能在不管事务是否完成的状况下保持一致状态。
好比,银行转帐,好比保证从一个帐户减小和另外一个帐户增长的操做完整完成。

ACID原则,就是描述事务安全性的4个需求:
Atomicity(原子性)---一个事务必须是原子性的,它必须是做为一个总体彻底执行或者彻底不执行。
Consistency(一致性)---一个 事务必须可以使数据库处于一致的状态。
Isoltion(孤立性)---未彻底完成的 事务不能被数据库的其余用户所见,也就是说,在事务彻底完成以前,它们都是孤立的。
Durability(持续性)---一旦写入到数据库后,事务必须是永久的并且持续的。
注意:一个事务被永久地写入到数据库中称做该事务被提交了。一个没有写入到数据库中的事务(所以数据库将状态重置到事务开始以前的状态)称做事务被回滚了。

三、关系数据库
关系数据库代替普通文件的优势:
1)关系数据库比普通文件的数据访问速度更快。
2)关系数据库更容易查询并提取知足特定条件的数据。
3)关系数据库具备专门的内置机制处理并发访问。
4)关系数据库能够提供对数据的随机访问
5)关系数据库具备内置的权限系统。

四、关系数据库的一些基本概念
1)关系数据库由“关系”组成,这些关系一般称为“表格”

2)列
“列”又叫作“域”或者“属性”
每一列都有一个惟一的名称,和一个相关的数据类型。
3)行
每一行具备相同的格式,也具备相同的属性。行也叫“记录”。
4)值
每一个值必须与该列定义的数据类型相同。
5)键
咱们必须有一个可以识别每个特定记录的方法。
表中的标志列成为“键”或“主键”。
数据库由多个表组成,可使用键做为表格之间的引用。


6)模式
数据库整套表格的完整设计称为数据库的“模式”。它是数据库的设计蓝图。
一个模式应该显示表格及表格的列、各个表的主键和外键。
能够包含示例数据来解析这些数据的含义。


7)关系
关系数据库中有3种基本的关系类型,一对1、一对多、多对多。

四、设计Web数据库
知道何时须要一个新表,以及须要哪些键,须要掌握很高的技巧。可是在大多数状况下,咱们能够遵循一些基本的原则。

1)考虑实际建模的对象,现实世界对应的对象
2)避免冗余数据
冗余数据将致使两个主要问题:
a. 空间的浪费
b. 数据更新的不一致,数据的完整性将被破坏。(修改、插入和删除时容易致使)
c. 使用原子列值:每一行的每一个属性只存储一个数据。
若是咱们想在格子里存多个数据值,其实至关于建立了一个表中表,这样系统就不能只计算匹配字段了,而必须分析每一个属性值,看系统中是否包含一个匹配。因此,看状况而定吧。
d. 选择有意义的键
e. 考虑须要询问数据库的问题,想想咱们但愿数据库回答什么问题,而后确认数据库中是否已经包含全部须要的数据,而且在表之间要有适当的关联。
f. 避免多个空属性的设计。
数据库里有不少空值,很糟糕。首先,浪费空间。其次,在统计列总量或对其余数值列应用计算函数时可能致使错误。还有,当用户看到表中一部分为空时。也很迷惑,他们也不知道是否由于该属性是无关的,仍是数据库中有错误,或者是数据还没有输入。

五、表类型总结
1)描述现实世界对象的简单表
2)描述两个现实世界对象的多对多关系的关联表。

六、Web数据库的架构 数据库

一般,Web服务器软件,PHP引擎和数据库服务器都在同一台机器上运行。可是数据库服务器在另一台机器上运行也很常见,这样是出于安全性、提升性能以及负载均衡的缘由。
随着应用程序在大小和复杂度上不断增长,咱们可能会将PHP应用程序分红不一样的层,一般,包括与MySQL交互的数据库层、包含了应用程序的业务逻辑成、管理HTML输出的表示层。
相关文章
相关标签/搜索