文档章节

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

slyso
 slyso
发布于 2015/11/19 21:32
字数 2080
阅读 142
收藏 5
点赞 0
评论 0
1、存储引擎
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版本中好像支持全文索引了。

2、事务
事务是确保数据库一致的机制,尤其是在发生错误或服务器崩溃情况下确保数据库一致的机制。
事务是一个或一系列的查询,这些查询可以保证能够在数据库中作为一个整体全部执行或者全部不执行。这样,数据库才能在无论事务是否完成的情况下保持一致状态。
比如,银行转账,比如保证从一个账户减少和另一个账户增加的操作完整完成。

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

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

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

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


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


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

4、设计Web数据库
知道什么时候需要一个新表,以及需要哪些键,需要掌握很高的技巧。但是在大多数情况下,我们可以遵循一些基本的原则。

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

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

6、Web数据库的架构

通常,Web服务器软件,PHP引擎和数据库服务器都在同一台机器上运行。但是数据库服务器在另外一台机器上运行也很常见,这样是出于安全性、提高性能以及负载均衡的原因。
随着应用程序在大小和复杂度上不断增加,我们可能会将PHP应用程序分成不同的层,通常,包括与MySQL交互的数据库层、包含了应用程序的业务逻辑成、管理HTML输出的表示层。

© 著作权归作者所有

共有 人打赏支持
slyso
粉丝 23
博文 28
码字总数 52229
作品 0
美国
个人站长
读《PHP和MySQL Web开发》

【第一部分】PHP基础与入门 1、PHP学习笔记1:基础知识快速浏览 http://my.oschina.net/bluefly/blog/472673 2、PHP学习笔记2:文件 http://my.oschina.net/bluefly/blog/477601 3、PHP学习笔...

slyso ⋅ 2015/07/14 ⋅ 0

分享35本关于PHP的学习书籍(免费下载)

分享35本关于PHP的学习书籍(免费下载) 1、PHP面向对象编程 2、PHP与MVC开发模式 3、PHP面向对象教程(强力推荐) 4、Smarty php模板引擎 5、phpmysqlwebdbs 6、PHP和MySQLWEB开发部分3 7、P...

邓剑彬 ⋅ 2012/12/01 ⋅ 4

后台开发常问面试题集锦(问题搬运工,附链接)

Java基础问题 String的’+’的性能及原理 java之yield(),sleep(),wait()区别详解-备忘笔记 深入理解Java Stream流水线 抽象 & abstract关键字 Java final 修饰符知识点总结(必看篇) Java中的...

大黄有故事 ⋅ 2017/11/18 ⋅ 0

《PHP基础知识总结》系列-新鸟老鸟通吃

《PHP基础知识总结》文件夹收藏文章列表 总结PHP基础知识,对初学者还是高手都值得参考巩固。 1PHP检查库或函数是否可用的方法 2关于PHP5 Session生命周期介绍 3PHP页面和Mysql数据库的转UTF...

开元中国2015 ⋅ 2015/05/06 ⋅ 0

开源电子书

目录 语言无关类 操作系统 智能系统 分布式系统 编译原理 函数式概念 计算机图形学 WEB服务器 版本控制 编辑器 NoSQL PostgreSQL MySQL 管理和监控 项目相关 设计模式 Web 大数据 编程艺术 ...

zting科技 ⋅ 2017/12/11 ⋅ 0

免费的编程中文书籍索引

免费的编程中文书籍索引,欢迎投稿。 国外程序员在 stackoverflow 推荐的程序员必读书籍,中文版。 stackoverflow 上的程序员应该阅读的非编程类书籍有哪些? 中文版 github 上的一个流行的编...

modernizr ⋅ 2014/04/08 ⋅ 24

Fanta/free-programming-books-zh_CN

免费的编程中文书籍索引 免费的编程中文书籍索引,欢迎投稿。 国外程序员在 stackoverflow 推荐的程序员必读书籍,中文版。 stackoverflow 上的程序员应该阅读的非编程类书籍有哪些? 中文版...

Fanta ⋅ 2016/11/14 ⋅ 0

所看书籍记录

《程序员教程(第三版)》 《深入理解计算机系统》 《程序员的自我修养--链接、装载与库》(两遍) 《编译原理(龙书)》 《现代操作系统(第三版)》 《图解网络硬件》 《图解TCP/IP》 《数据...

thanatos_y ⋅ 2016/03/14 ⋅ 0

全栈必备 个人环境

“工其事必先利其器”,对于一个全栈而言,一个与自己匹配的开发和学习环境,能够极大地提高个人的工作效率,很多时候都可以做到事半而功倍。环境也是一个外延很广的概念,这里我所涉及的包括...

wireless_com ⋅ 2016/11/13 ⋅ 0

技术积累笔记概要

2015年11月24日 1、rest 速率限制,写属于自己的方法。 2、actions方法深刻了解。 3、YII技术博客:http://blog.csdn.net/terrywater/article/category/2565815。 4、静态方法传递参数的习惯...

风清扬-深圳 ⋅ 2015/11/24 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

vue-cli是什么?

vue-cli是什么? vue-cli 是vue.js的脚手架,用于自动生成vue.js+webpack的项目模板,分为vue init webpack-simple 项目名 和vue init webpack 项目名 两种。 当然首先你的安装vue,webpack...

韦姣敏 ⋅ 9分钟前 ⋅ 0

12c rman中输入sql命令

12c之前版本,要在rman中执行sql语句,必须使用sql "alter system switch logfile"; 而在12c版本中,可以支持大量的sql语句了: 比如: C:\Users\zhengquan>rman target / 恢复管理器: Release 1...

tututu_jiang ⋅ 15分钟前 ⋅ 0

java 线程池

概述 减少了创建和销毁线程的次数,每个工作线程都可以被重复利用,可执行多个任务 可以根据系统的承受能力,调整线程池中工作线线程的数目,防止因为因为消耗过多的内存,而把服务器累趴下(...

轨迹_ ⋅ 20分钟前 ⋅ 0

Nginx的https配置记录以及http强制跳转到https的方法梳理

Nginx的https配置记录以及http强制跳转到https的方法梳理 一、Nginx安装(略) 安装的时候需要注意加上 --with-httpsslmodule,因为httpsslmodule不属于Nginx的基本模块。 Nginx安装方法: ...

Yomut ⋅ 32分钟前 ⋅ 0

SpringCloud Feign 传递复杂参数对象需要注意的地方

1.传递复杂参数对象需要用Post,另外需要注意,Feign不支持使用GetMapping 和PostMapping @RequestMapping(value="user/save",method=RequestMethod.POST) 2.在传递的过程中,复杂对象使用...

@林文龙 ⋅ 33分钟前 ⋅ 0

如何显示 word 左侧目录大纲

打开word说明文档,如下图,我们发现左侧根本就没有目录,给我们带来很大的阅读障碍 2 在word文档的头部菜单栏中,切换到”视图“选项卡 3 然后勾选“导航窗格”选项 4 我们会惊奇的发现左侧...

二营长意大利炮 ⋅ 37分钟前 ⋅ 0

智能合约编程语言Solidity之线上开发工具

工具地址:https://ethereum.github.io/browser-solidity/ 实例实验: 1.创建hello.sol文件 2.调试输出结果

硅谷课堂 ⋅ 37分钟前 ⋅ 0

ffmpeg 视频格式转换

转 Mp4 格式 #> ffmpeg -i input.avi -c:v libx264 output.mp4#> ffmpeg -i input.avi -c:v libx264 -strict -2 output.mp4#> ffmpeg -i input.avi -c:v libx264 -strict -2 -s 1......

Contac ⋅ 49分钟前 ⋅ 0

VCS仿真生成vpd文件(verilog)

VCS仿真生成vpd文件(verilog): https://www.cnblogs.com/OneFri/p/5987673.html SYNOPSYS VCS常用命令使用详解 https://blog.csdn.net/hemmingway/article/details/49382551 DVE是synopsys公......

whoisliang ⋅ 56分钟前 ⋅ 0

Spring Boot启动配置原理

几个重要的事件回调机制 配置在META-INF/spring.factories ApplicationContextInitializer SpringApplicationRunListener 只需要放在ioc容器中 ApplicationRunner CommandLineRunner 启动流程......

小致dad ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部