MySQL数据库技术大全_第1页
MySQL数据库技术大全_第2页
MySQL数据库技术大全_第3页
MySQL数据库技术大全_第4页
MySQL数据库技术大全_第5页
已阅读5页,还剩107页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

tSSi

白嬉学吧

MySQL数据库技术大全

MLJSQL®

目录

一、数据库概要...............................................................................5

11、发展历史......................................................................5

1.1.1.人工处理阶段...........................................................5

1.1.2.文件系统..............................................................6

1.1.3、数据库管理系统........................................................6

1.2、常见数据库技术品牌、服务与架构..............................................9

1.3、数据库分类...................................................................11

1.3.1、关系型数据库..........................................................11

1.3.2、非关系型数据库.......................................................11

1.4、数据库规范化................................................................12

1.4.1.什么是范式............................................................12

1.4.2.三大范式..............................................................13

1.4.3.范式与效率............................................................17

二、MySQL介绍.............................................................................18

2.1、MySQL概要.................................................................18

2.2、系统特性....................................................................19

2.3、存储引擎....................................................................20

三、快速安装运行MySQL数据库.............................................................22

3.1、使用绿色版..................................................................22

3.1.1、设置mysql远程访问..................................................26

3.1.2、修改mysql用户密码..................................................27

3.1.2、安装服务.............................................................28

3.2、使用安装版..................................................................30

四、使用GUI操作MySQL........................................................................................................................................45

4.1、关系型数据库的典型概念.....................................................45

4.2、登录数据库..................................................................47

4.3、创建数据库..................................................................49

4.4、创建表......................................................................50

4.5、管理数据....................................................................53

4.5」、添加数据............................................................53

4.5.2、删除数据............................................................54

4.5.3、修改表结构..........................................................55

4.5.4、外键................................................................56

4.5.5、唯一健..............................................................60

4.6、上机练习....................................................................61

五、使用SQL访问MySQL数据库............................................................63

5.1、增加数据....................................................................63

5.2、查询数据....................................................................63

5.2.1、表达式与条件查询.....................................................64

5.2.2、聚合函数.............................................................65

5.3、删除数据....................................................................66

5.4、更新数据....................................................................66

5.5、修改表......................................................................66

5.5.1、添加列................................................................67

5.5.2、修改列................................................................67

5.5.3、删除列................................................................67

5.5.4、重命名表.............................................................68

5.5.5、删除表................................................................68

5.5.6、删除数据库............................................................68

5.5.7、一千行MySQL笔记...................................................68

5.5.8、常用的SQL...................................................................................................104

白鸽学吧

随着移动互联网的结束与人工智能的到来大数据变成越来越重要,下一个成功者应该是拥

有海量数据的,数据与数据库你应该知道。

一、数据库概要

数据库(Database)是存储与管理数据的软件系统,就像一个存入数据的物流仓库。

在商业领域,信息就意味着商机,取得信息的一个非常重要的途径就是对数据进行分析处理,

这就催生了各种专业的数据管理软件,数据库就是其中的一种。当然,数据库管理系统也不是

一下子就建立起来,它也是经过了不断的丰富和发展,才有了今天的模样。

1.1、发展历史

1.1.1,人工处理阶段

白鸽学吧

在20世纪50年代中期以前的计算机诞生初期,其处理能力很有限,只能够完成一些简单的运

算,数据处理能力也很有限,这使得当时的计算机只能够用于科学和工程计算。计算机上没有

专用的管理数据的软件,数据由计算机或处理它的程序自行携带。当数据的存储格式、读写路

径或方法发生变化的时候,其处理程序也必须要做出相应的改变以保持程序的正确性。

1.1.2、文件系统

20世纪50年代后期到60年代中期,随着硬件和软件技术的发展,计算机不仅用于科学计算,

还大量用于商业管理中。在这一时期,数据和程序在存储位置上已经完全分开,数据被单独组

织成文件保存到外部存储设备上,这样数据文件就可以为多个不同的程序在不同的时间所使用。

虽然程序和数据在存储位置上分开了,而且操作系统也可以帮助我们对完成了数据的存储位置

和存取路径的管理,但是程序设计仍然受到数据存储格式和方法的影响,不能够完全独立于数

据,而且数据的冗余较大。

1.1.3、数据库管理系统

从20世纪70年代以来,计算机软硬件技术取得了飞跃式的发展,这一时期最主要的发展就是

产生了真正意义上的数据库管理系统,它使得应用程序和数据之间真正的实现的接口统一、数

白鸽学吧

据共享等,这样应用程序都可以按照统一的方式直接操作数据,也就是应用程序和数据都具有

了高度的独立性。

一张图清晰追溯数据库的发展历程(1962-2016)

在IDSW亍的年代,(硅谷的伴随阿波罗登月计划,商

所碰)加利佛摩州,21mm雏形雌IBM

gglMS,Mainframe^

(database)

navigational数据库

CROSSREFERENCE一词最早流行

耶于系统研

H发公司的函

埃德加・弗兰克•科德IBM

X技术备忘录

司研究员,发表题为“大型

共享数据库的关系模型"的

AftCCOROMAY

KCtMSRtftt-论文,被誉为关系数据库

TMUAS

wassAw66D

T1974

|的校企联合计划中,与加

利佛创洲jfSlhngres

■库研究项目携手创建了

1983—-01979

e发布熟一套自主开发

IBM分级结构

的关系型数据库管理系统)并将萌芽;关系型

结构业务剥离

1984

Oracle

天睿公司(TerodataCorpo-

第一个商业RDBMS

ration)发布第大规模并行

处理(MPP)

白嬉学吧

1.2、常见数据库技术品牌、服务与架构

发展了这么多年市场上出现了许多的数据库系统,最强的个人认为是Oracle,当然还有许多

如:DB2、MicrosoftSQLServer.MySQL、SyBase等,下图列出常见数据库技术品牌、服

务与架构。

SupportedDataTechnologies

M人巅矗期f°DB抵念

皿温.那riakspiunk>

Ade(gehstieswreh.

Smahout

Spar^

rlfllIflPM燕、G鲁amazon吧。,no311132011

LIUUUIHortonworksDynamoDBSimpleDBwebsewcesStreaming

AmazonRedshift

OSQLSystemsONoSQLSystemsOBigDataSupport

SfMySQl©Y."后▼Hadoop.Map-reduce

&&Iq

&Oracle&Cassandra✓DataInsights

&SQLServerSTRed:s3DataDiscovery

@rRiak3RealtimeAnalytics

©AnalyticSystemsSTNeo4J3MachineLearning

&Ur—®DynamoDBoPredictiveAnaiytics

&SAPHana&SimpleDB

&OouderaimpalaDataArchitecture

❷DataComponents

GTBtgQuerv3Evaluation

&Redshift&Splunk✓Proofofconcept

6?ElasticSearch3Transformation

DataWarehouse&Sok3Implementation

&@Node.JS3SoftwareArchitecture

&Hive©AmazonSNS,SOS3TechnologyStrategy

&ApachePIGSTZookeeper3CTOAdvisory

&BlSTStormy

&ETL8Spark3MigrationToBigData

&OLARReporting&Kafka

&RabbitMQ

传传报盘Kainayi]wyt]鼠网可u化

接口层IMtitiggWp/FTWBEST/Sodt)]国副曲XMt/JSON|)]连携号

HBS统一计算彤务

•ttHNW^RichHadoop内等计加应架RichSpark

■■男muJ

战一负袤网度着理相施YARN

行情层丸制8|•t»K

白鸽学吧

1.3、数据库分类

数据库通常分为层次式数据库、网络式数据库和关系式数据库三种。

而不同的数据库是按不同的数据结构来联系和组织的。

而在当今的互联网中,最常见的数据库模型主要是两种,即关系型数据库和非关系型数据库。

1.3.1,关系型数据库

当前在成熟应用且服务与各种系统的主力数据库还是关系型数据库。

编号姓名语文数学英语

201701张三995130

201702李四391591

201703王五921351

201704赵六399967

201705牛七566990

代表:Oracle、SQLServer,MySQL

1.3.2、非关系型数据库

白鸽学吧

随着时代的进步与发展的需要,非关系型数据库应运而生。

代表:Redis、Mongodb

NoSQL数据库在存储速度与灵活性方面有优势,也常用于缓存。

1.4、数据库规范化

经过一系列的步骤,我们现在终于将客户的需求转换为数据表并确立这些表之间的关系,那么

是否我们现在就可以在开发中使用呢?答案否定的,为什么呢!同一个项目,很多人参与了需

求的分析,数据库的设计,不同的人具有不同的想法,不同的部门具有不同的业务需求,我们

以此设计的数据库将不可避免的包含大量相同的数据,在结构上也有可能产生冲突,在开发中

造成不便。

1.4.1.什么是范式

要设计规范化的数据库,就要求我们根据数据库设计范式一也就是数据库设计的规范原则来做。

范式可以指导我们更好地设计数据库的表结构,减少冗余的数据,借此可以提高数据库的存储

效率,数据完整性和可扩展性。

设计关系数据库时,遵从不同的规范要求,设计出合理的关系型数据库,这些不同的规范要求

被称为不同的范式,各种范式呈递次规范,越高的范式数据库冗余越小。目前关系数据库有六

种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、巴德斯科范式(BCNF)、

白鸽学吧

第四范式(4NF)和第五范式(5NF,又称完美范式)。满足最低要求的范式是第一范式(1NF)。

在第一范式的基础上进一步满足更多规范要求的称为第二范式(2NF),其余范式以次类推。

一般说来,数据库只需满足第三范式(3NF)就行了。

1.4.2.三大范式

第一范式(1NF)

所谓第一范式(1NF)是指在关系模型中,对列添加的一个规范要求,所有的列都应该是原子

性的,即数据库表的每一列都是不可分割的原子数据项,而不能是集合,数组,记录等非原子

数据项。即实体中的某个属性有多个值时,必须拆分为不同的属性。在符合第一范式(1NF)

表中的每个域值只能是实体的一个属性或一个属性的一部分。简而言之,第一范式就是无重复

的域。

例如:表1-1中,其中“工程地址”列还可以细分为省份,城市等。在国外,更多的程序把"姓

名"列也分成2列,即"姓"和"名"。

虽然第一范式要求各列要保存原子性,不能再分,但是这种要求和我们的需求是相关联的,如

上表中我们对"工程地址”没有省份,城市这样方面的查询和应用需求,则不需拆分,"姓名"

列也是同样如此。

表1-1原始表

白鸽学吧

==

工程号工程名称工程地址贝工骊W员工名称薪资待遇职务

P001港珠澳大桥广东珠海E0001Jack6000/月工人

P001港珠澳大桥广东珠海E0002Join7800/月工人

P001港珠澳大桥广东珠海E0003Apple8000/月高级技工

P002南海航天海南三亚E0001Jack5000/月工人

第二范式(2NF)

在1NF的基础上,非Key属性必须完全依赖于主键。第二范式(2NF)是在第一范式(1NF)

的基础上建立起来的,即满足第二范式(2NF)必须先满足第一范式(1NF)。第二范式(2NF)

要求数据库表中的每个实例或记录必须可以被唯一地区分。选取一个能区分每个实体的属性或

属性组,作为实体的唯一标识。

第二范式(2NF)要求实体的属性完全依赖于主关键字。所谓完全依赖是指不能存在仅依赖主

关键字一部分的属性,如果存在,那么这个属性和主关键字的这一部分应该分离出来形成一个

新的实体,新实体与原实体之间是一对多的关系。为实现区分通常需要为表加上一个列,以存

储各个实例的唯一标识。简而言之,第二范式就是在第一范式的基础上属性完全依赖于主键。

例如:表1-1中,一个表描述了工程信息,员工信息等。这样就造成了大量数据的重复。按照第

二范式,我们可以将表1-1拆分成表1-2和表1-3:

I工程信息表:(工程编号,工程名称,工程地址):

白鸽学吧

表1-2工程信息表

工程编号工程名称工程地址

P001港珠澳大桥广东珠海

P002南海航天海南三亚

I员工信息表(员工编号,员工名称,职务,薪资水平):

表1-3员工信息表

贝=工T骊4^弓=员工姓名职务薪资水平

E0001Jack工人3000/月

E0002Join工人3000/月

E0003Apple高级技工6000/月

这样,表1-1就变成了两张表,每个表只描述一件事,清晰明了。

第三范式(3NF)

第三范式是在第二范式基础上,更进一层,第三范式的目标就是确保表中各列与主键列直接相

关,而不是间接相关。即各列与主键列都是一种直接依赖关系,则满足第三范式。

第三范式要求各列与主键列直接相关,我们可以这样理解,假设张三是李四的兵,王五则是张

三的兵,这时王五是不是李四的兵呢?从这个关系中我们可以看出,王五也是李四的兵,因为王

白鸽学吧

五依赖于张三,而张三是李四的兵,所以王五也是。这中间就存在一种间接依赖的关系而非我

们第三范式中强调的直接依赖。

现在我们来看看在第二范式的讲解中,我们将表1-1拆分成了两张表。这两个表是否符合第三

范式呢。在员工信息表中包含:"员工编号"、"员工名称"、"职务"、"薪资水平",而

我们知道,薪资水平是有职务决定,这里“薪资水平"通过"职务”与员工相关,则不符合第

三范式。我们需要将员工信息表进一步拆分,如下:

I员工信息表:员工编号,员工名称,职务

I职务表:职务编号,职务名称,薪资水平

现在我们已经了解了数据库规范化设计的三大范式,下面我们再来看看对表1-1优化后的数据

表:

员工信息表(Employee)

贝=工T-骊W=员工姓名职务编号

E0001Jack1

E0002Join1

E0003Apple2

工程信息表(Projectinfo)

工程编号工程名称工程地址

P001港珠澳大桥广东珠海

白鸽学吧

P002南海航天海南三亚

职务表(Duty)

职务编号职务名称工资待遇

1工人3000/月

2高级技工6000/月

工程参与人员记录表(Project.Employee_info)

q=1=但=

工程编号人K骊E

1P001E0001

2P001E0002

3P002E0003

通过对比我们发现,表多了,关系复杂了,查询数据变的麻烦了,编程中的难度也提高了,但

是各个表中内容更清晰了,重复的数据少了,更新和维护变的更容易了,哪么如何平衡这种矛

盾呢?

1.4.3,范式与效率

在我们设计数据库时,设计人员、客户、开发人员通常对数据库的设计有一定的矛盾,客户更

喜欢方便,清晰的结果,开发人员也希望数据库关系比较简单,降低开发难度,而设计人员则

需要应用三大范式对数据库进行严格规范化,减少数据冗余,提高数据库可维护性和扩展性。

由此可以看出,为了满足三大范式,我们数据库设计将会与客户、开发人员产生分歧,所以在

白鸽学吧

实际的数据库设计中,我们不能一味的追求规范化,既要考虑三大范式,减少数据冗余和各种

数据库操作异常,又要充分考虑到数据库的性能问题,允许适当的数据库冗余。

二、MySQL介绍

2.1、MySQL概要

MySQL是一个关系型数据库管理系统,由瑞典MySQLAB公司开发,目前属于Oracle旗

下产品。MySQL是最流行的关系型数据库管理系统之一,在WEB应用方面,MySQL是最

好的RDBMS(RelationalDatabaseManagementSystem,关系数据库管理系统)应用软

件之一。

MySQL@

MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数

据放在一个大仓库内,这样就增加了速度并提高了灵活性。

白鸽学吧

MySQL所使用的SQL语言是用于访问数据库的最常用标准化语言。MySQL软件采用了双

授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码

这一特点,一般中小型网站的开发都选择MySQL作为网站数据库。

MySQL官网:/

MySQL下载:/downloads/

2.2、系统特性

1、使用C和C++编写,并使用了多种编译器进行测试,保证了源代码的可移植性。

2、支持AIX、FreeBSD、HP-UX、Linux、MacOS、NovellNetware.OpenBSD.OS/2Wrap、

Solaris,Windows等多种操作系统。

、为多种编程语言提供了这些编程语言包括、+、、、、

3APIOCC+Python.JavaPerlPHP

EiffeLRuby,.NET和Tel等。

4、支持多线程,充分利用CPU资源。

5、优化的SQL查询算法,有效地提高查询速度。

6、既能够作为一个单独的应用程序应用在客户端服务器网络环境中,也能够作为一个库而嵌

入到其他的软件中。

7、提供多语言支持,常见

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论