资源描述
MySQL简介:
MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最佳的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件。
MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增长了速度并提高了灵活性。
MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,特别是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。
由于其社区版的性能卓越,搭配 PHP 和 Apache 可组成良好的开发环境。
数据库事务的四个特性及含义
数据库事务transanction对的执行的四个基本要素。ACID,原子性(Atomicity)、一致性(Correspondence)、隔离性(Isolation)、持久性(Durability)。
原子性:整个事务中的所有操作,要么所有完毕,要么所有不完毕,不也许停滞在中间某个环节。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这个事务历来没有执行过同样。
一致性:在事务开始之前和事务结束以后,数据库的完整性约束没有被破坏。
隔离性:隔离状态执行事务,使它们仿佛是系统在给定期间内执行的唯一操作。假如有两个事务,运营在相同的时间内,执行 相同的功能,事务的隔离性将保证每一事务在系统中认为只有该事务在使用系统。这种属性有时称为串行化,为了防止事务操作间的混淆,必须串行化或序列化请 求,使得在同一时间仅有一个请求用于同一数据。
持久性:在事务完毕以后,该事务所对数据库所作的更改便持久的保存在数据库之中,并不会被回滚。
视图的作用
视图是虚拟的表,与包含数据的表不同样,视图只包含使用时动态检索数据的查询;不包含任何列或数据。使用视图可以简化复杂的sql操作,隐藏具体的细节,保护数据;视图创建后,可以使用与表相同的方式运用它们。
视图不能被索引,也不能有关联的触发器或默认值,假如视图自身内有order by 则对视图再次order by将被覆盖。
创建视图:create view XXX as XXXXXXXXXXXXXX;
对于某些视图比如未使用联结子查询分组聚集函数Distinct Union等,是可以对其更新的,对视图的更新将对基表进行更新;但是视图重要用于简化检索,保护数据,并不用于更新,并且大部分视图都不可以更新。
数据库范式
第一范式(1NF)
在任何一个关系数据库中,第一范式(1NF)是对关系模式的基本规定,不满足第一范式(1NF)的数据库就不是关系数据库。
所谓第一范式(1NF)是指数据库表的每一列都是不可分割的基本数据项,同一列中不能有多个值,即实体中的某个属性不能有多个值或者不能有反复的属性。假如出现反复的属性,就也许需要定义一个新的实体,新的实体由反复的属性构成,新实体与原实体之间为一对多关系。在第一范式(1NF)中表的每一行只包含一个实例的信息。简而言之,第一范式就是无反复的列。
第二范式(2NF)
第二范式(2NF)是在第一范式(1NF)的基础上建立起来的,即满足第二范式(2NF)必须先满足第一范式(1NF)。第二范式(2NF)规定数据库表中的每个实例或行必须可以被惟一地区分。为实现区分通常需要为表加上一个列,以存储各个实例的惟一标记。这个惟一属性列被称为主关键字或主键、主码。
第二范式(2NF)规定实体的属性完全依赖于主关键字。所谓完全依赖是指不能存在仅依赖主关键字一部分的属性,假如存在,那么这个属性和主关键字的这一部分应当分离出来形成一个新的实体,新实体与原实体之间是一对多的关系。为实现区分通常需要为表加上一个列,以存储各个实例的惟一标记。简而言之,第二范式就是非主属性非部分依赖于主关键字。
第三范式(3NF)
满足第三范式(3NF)必须先满足第二范式(2NF)。简而言之,第三范式(3NF)规定一个数据库表中不包含已在其它表中已包含的非主关键字信息。例如,存在一个部门信息表,其中每个部门有部门编号(dept_id)、部门名称、部门简介等信息。那么在员工信息表中列出部门编号后就不能再将部门名称、部门简介等与部门有关的信息再加入员工信息表中。假如不存在部门信息表,则根据第三范式(3NF)也应当构建它,否则就会有大量的数据冗余。简而言之,第三范式就是属性不依赖于其它非主属性。(我的理解是消除冗余)
存储过程与触发器的区别
触发器与存储过程非常相似,触发器也是SQL语句集,两者唯一的区别是触发器不能用EXECUTE语句调用,而是在用户执行Transact-SQL语句时自动触发(激活)执行。触发器是在一个修改了指定表中的数据时执行的存储过程。通常通过创建触发器来强制实现不同表中的逻辑相关数据的引用完整性和一致性。由于用户不能绕过触发器,所以可以用它来强制实行复杂的业务规则,以保证数据的完整性。触发器不同于存储过程,触发器重要是通过事件执行触发而被执行的,而存储过程可以通过存储过程名称名字而直接调用。当对某一表进行诸如UPDATE、INSERT、DELETE这些操作时,SQLSERVER就会自动执行触发器所定义的SQL语句,从而保证对数据的解决必须符合这些SQL语句所定义的规则。
索引有关问题
1. MySQL 有哪些存储引擎啊?都有什么区别?
2. Float、Decimal 存储金额的区别?
3. Datetime、Timestamp 存储时间的区别?
4. Char、Varchar、Varbinary 存储字符的区别?
5. 什么是索引?
6. 对比一下B+树索引和 Hash索引?
7. MySQL索引类型有?
8. 如何管理 MySQL索引?
9. 对Explain参数及重要参数的理解?
10. 索引利弊是什么及索引分类?
11. 二叉树的转置是什么?
12. 聚簇索引和非聚簇索引的区别?
13. B+tree 如何进行优化?索引遵循哪些原则?存储引擎会进行哪些自动优化?到底何时索引会失效?
14. 索引与锁有什么关系?
15. 尚有什么其他的索引类型,各自索引有哪些优缺陷?
展开阅读全文