Mysql 第一篇:初识数据库
第一篇:初识数据库
一、数据库管理软件的由来
基于我们之前所学,数据要想永久保存,都是保存于文件中,毫无疑问一个文件仅仅只能存在于某一台机器上。
如果我们暂且忽略直接基于文件来存取数据的效率问题,并且假设程序所有的组件都运行在一台机器上,那么用文件存取数据,并没有问题。
很不幸,这些假设都是你自己意淫出来的,上诉假设存在以下几个问题:
1.程序所有的组件就不可能运行在一台机器上
#因为这台机器一旦挂掉则意味着整个软件的崩溃,并且程序的执行效率依赖于承载它的硬件,
而一台机器的性能总归是有限的,受限于目前的硬件水平,就一台机器的性能垂直进行扩展是有极限的
#于是我们只能通过水平扩展来增强我们系统的整体性能,这就需要我们将程序的各个组件分布于多台机器去执行
2.数据安全问题
#根据1的描述,我们将程序的各个组件分布到各台机器,但需知各组件仍然是一个整体,言外之意,
所有组件的数据还是要共享的。但每台机器上的组件都只能操作本机的文件,这就导致了数据不然一致
#于是我们想到看将数据与应用程序分离,把文件存放于一台机器,然后将多台机器通过网络去访问这台机器上的文件(用socket实现),
即共享这台机器上的文件,共享则意味着竞争,会发生数据不安全,需要加锁处理。
3、并发
#根据2的描述,我们必须写一个socket服务端来管理这台机器(数据库服务器)上的文件,然后写一个socket客户端,完成如下功能:
#1.远程连接(支持并发)
#2.打开文件
#3.读写(加锁)
#4.关闭文件
总结:
我们在编写任何程序之前,都需要事先写好基于网络操作一台主机上文件的程序(socket服务端与客户端),于是有人讲此程序写成一个专门的处理软件,
这就是mysql等数据库管理软件的由来,但是mysql解决的不仅仅是数据共享的问题,还有查询效率,
安全性等一系列问题,总之,把程序员从数据管理中解脱出来,专注于自己的程序逻辑的编写
二、数据库的概述
1 什么是数据(Data)
描述事物的符号记录称为数据
egon,male,18,1999,山东,计算机系,2017
大家所知道的都是数据.比如:你同学的名字,年龄,性别等等
单纯的一条记录并没有任何意义,如果我们按逗号作为分隔,依次定义各个字段的意思,相当于定义表的标题
1 name,sex,age,birth,born_addr,major, #字段
2 egon,male,18,1999,山东,计算机系,2017, #记录
这样我们就可以了解egon,性别为男,年龄18岁,出生于1999年,出生地为山东
2.什么是数据库
数据库即存放数据的仓库,只不过这个仓库是在计算机存储设备上,而且数据是按一定的格式存放的
3.数据库的特点
⑴ 实现数据共享
数据共享包含所有用户可同时存取数据库中的数据,也包括用户可以用各种方式通过接口使用数据库,并提供数据共享。
⑵ 减少数据的冗余度
同文件系统相比,由于数据库实现了数据共享,从而避免了用户各自建立应用文件。减少了大量重复数据,减少了数据冗余,维护了数据的一致性。
⑶ 数据一致性和可维护性,以确保数据的安全性和可靠性
主要包括:①安全性控制:以防止数据丢失、错误更新和越权使用;
②完整性控制:保证数据的正确性、有效性和相容性;
③并发控制:使在同一时间周期内,允许对数据实现多路存取,又能防止用户之间的不正常交互作用。
⑷ 故障恢复
由数据库管理系统提供一套方法,可及时发现故障和修复故障,从而防止数据被破坏。数据库系统能尽快恢复数据库系统运行时出现的故障,
可能是物理上或是逻辑上的错误。比如对系统的误操作造成的数据错误等。
三、数据库的下载和安装
https://jingyan.baidu.com/article/cd4c2979033a17756f6e6047.html
四、初识sql语句
数据管理系统可以接收一些命令,对数据文件进行添加、删除、修改、查询等操作,这些命令就是SQL
SQL:(Structured Query Language)是结构化查询语言缩写。是一门专门与数据库管理系统打交道的语言。
具体可以把SQL分为4个部分:
数据控制语言 ( DCL): 主要用于控制用户的访问权限。其中GRANT语句用于给用户增加权限,REVOKE语句用于收回用户的权限
数据定义语言(DDL):DROP、CREATE、ALTER等语句;
数据库定义语言。主要用于定义数据库,表,视图,索引和触发器等。
CREATE语句主要用于创建数据库,创建表,创建视图。
ALTER语句主要用于修改表的定义,修改视图的定义。
DROP语句主要用于删除数据库,删除表和删除视图等。
数据操作语言(DML):INSERT、UPDATE、DELETE语句;数据库操作语言。主要用于插入数据,更新数据,删除数据。
INSERT语句用于插入数据,UPDATE语句用于更新数据,DELETE语句用于删除数据.
数据查询语言(DQL):SELECT语句。主要用于查询数据。
#1. 操作文件夹
增:create database db1 charset utf8;
查:show databases;
改:alter database db1 charset latin1;
删除: drop database db1;
#2. 操作文件
先切换到文件夹下:use db1
增:create table t1(id int,name char);
查:show tables
改:alter table t1 modify name char(3);
alter table t1 change name name1 char(2);
删:drop table t1;
#3. 操作文件中的内容/记录
增:insert into t1 values(1,'egon1'),(2,'egon2'),(3,'egon3');
查:select * from t1;
改:update t1 set name='sb' where id=2;
删:delete from t1 where id=1;
清空表:
delete from t1; #如果有自增id,新增的数据,仍然是以删除前的最后一样作为起始。
truncate table t1;数据量大,删除速度比上一条快,且直接从零开始,
auto_increment 表示:自增
primary key 表示:约束(不能重复且不能为空);加速查找