当前位置: 首页 > article >正文

MySQL简介和管理

目录

一、数据库基本概念

1.1、数据

1.2、表

1.3、数据库

1.4、数据库管理系统

1.5、数据库系统

二、数据库发展史

2.1、第一代数据库

2.2、第二代数据库

2.3、第三代数据库

三、数据库类型

3.1、关系型数据库

3.2、关系型数据库应用

3.3、非关系型数据库

3.4、关系型数据库和非关系型数据库的区别

四、数据库管理命令

4.1、MySQL数据文件

4.2、MYSQL数据库的基本操作

五、SQL语句

5.1、数据定义语句

5.2、DML数据操作语言

5.3、DQL查询数据记录

5.4、DCL数据控制语言

5.5、扩展表结构(增加字段)

5.6、删除字段

5.7、创建临时表


一、数据库基本概念

1.1、数据

描述事物的符号记录称为数据(Data)。数字、文字、图形、图像、声音、档案记录等 都是数据。

数据是以“记录”的形式按照统一的格式进行存储的,而不是杂乱无章的。 相同格式和类型的数据统一存放在一起,而不会把“人”和“书”混在一起存储。这样,数据的存储就能够井然有序。

使用一些介质进行存储,例如文字存在文档中

数据库可以完成数据持久化保存+快速提取  

数据如何保存:最外层是mysql服务---》mysql数据库---》数据表---》记录为行,字段为列--->数据保存在一行行记录中,我们想要对存储在数据库中的数据进行管理,如需使用,我们就需要通过编写一系列的规则——SQL语句(命令行形式)

1.2、表

记录:行
字段(属性): 列
以行+列的形式就组成了表(数据存储在表中)
关系数据库的表由记录组成,记录由字段组成,字段由字符或数字组成。它可以供各种用户共享, 具有最小冗余度和较高的数据独立性,它是统一管理的相关数据的集合。

1.3、数据库

数据库就是表的集合。它是以一定的组织方式存储的相互有关的数据集合

1.4、数据库管理系统

数据库管理系统(DatabaseManagementSystem,DBMS)是实现对数据库资源有效组织、管理和存取的系统软件。它在操作系统的支持下,支持用户对数据库的各项操作;DBMS主要包括以下功能:

① 数据库的建立和维护功能:包括建立数据库的结构和数据的录入与转换、数据库的 转储与恢复、数据库的重组与性能监视等功能。

② 数据定义功能:包括定义全局数据结构、局部逻辑数据结构、存储结构、保密模式及信息格式等功能。保证存储在数据库中的数据正确、有效和相容,以防止不合语义的错误数据被输入或输出。

③ 数据操纵功能:包括数据查询统计和数据更新两个方面。

④ 数据库的运行管理功能:这是数据库管理系统的核心部分,包括并发控制、存取控 制、数据库内部维护等功能。

⑤ 通信功能:DBMS 与其他软件系统之间的通信,如 Access 能与其他 Office 组件进行数据交换。

1.5、数据库系统

数据库系统(DatabaseSystem,DBS)是一个人机系统,一般由硬件、操作系统、数据库、DBMS、应用软件和数据库用户(包括数据库管理员)组成。用户可以通过 DBMS 操作数据库,也可以通过应用程序操作数据库。

应用程序是利用DBMS为解决某个具体的管理或数据处理的任务而编制的一系列命令的有序集合。如果应用程序比较完善,能够提供友好的人机界面,并编译成可执行文件发行,使得普通用户不需要具备计算机的专业知识,在较短时间就学会使用,那么就称为数据库应用软件。( navicat)

常用的数据库应用软件有人事管理、财务管理、图书管理等信息管理软件及各类信息咨 询系统等。

数据库管理员(DatabaseAdministrator,DBA)负责数据库的更新和备份、数据库系统的维护、用户管理等工作,保证数据库系统的正常运行。DBA 一般由业务水平较高、资历较深的人员担任。

需要注意的是数据库、数据库系统、数据库管理系统,甚至数据库表等名词,在日常讨论中通常不严格区别。遇到此情况时,可以根据具体情况,判断出实际所指的是什么。

DBMS的工作模式如下:

①接受应用程序的数据请求和处理请求

②将用户的数据请求(高级指令)转换为复杂机器代码(底层指令)

③实现对数据库的操作

④从数据库的操作中接受查询结果

⑤对查询结果进行处理(格式转换)

⑥将处理结果返回给用户

二、数据库发展史

发展的三个阶段:
1、 层次型和网状型: 代表产品是1969年IBM公司研制的层次模型数据库管理系统IMS。
2、 关系型数据型库: 目前大部分数据库采用的是关系型数据库。1970年IBM公司的研究员E.F.Codd提出了关系模型。其代表产品为sysem R和Inges。
3、第三代数据库将为更加丰富的数据模型和更强大的数据管理功能为特征,以提供传统数据库系统难以支持的新应用。它必须支持面向对象,具有开放性,能够在多个平台上使用。管理技术的3个阶段1 人工管理2 文件管理3 数据库系统

2.1、第一代数据库

自20世纪60年代起,第一代数据库IMS系统问世

是层次模型与网状魔性的数据库系统

为同意管理和共享数据提供了有利的支撑

2.2、第二代数据库

20世纪70年代初,第二代数据库——关系数据库开始出现

20世纪80年代初,IBM公司的关系数据库系统DB2问世,开始逐步取代层次与网状模型的数据库,成为行业主流

到目前为止,关系数据库系统仍占领数据库应用的主要地位

2.3、第三代数据库

自20世纪80年代开始,适应不同领域的新型数据库系统不断涌现
面向对象的数据库系统,实用性强、适应面广
20世纪90年代后期,形成了多种数据库系统共同支撑应用的局面
一些新的元素被添加进主流数据库系统中。例如,Oracle 支持的 < 关系 - 对象 > 数据库模型

三、数据库类型

3.1、关系型数据库

关系型数据库是基于关系模型的数据库系统

关系模型的数据结构使用简单易懂的二维数据表

关系模型可用简单的 “实体 - 关系”(E - R) 图来表示

E - R 图中包含了实体(数据对象)、关系和属性三个要素(所有实体及实体之间联系的集合构成了一个关系数据库)

实体
也称为实例,对应现实世界中可区别于其他对象的“事件”或“事务”
如上图的银行客户,银行账户

属性
实体所具有的某一特性,一个实体可以有多个属性
如上图的 “银行客户” 实体集中的每个实体均具有姓名、住址、电话等属性

联系
实体集之间的对应关系称为联系,也称为关系
如银行客户和银行账户之间存在 “储蓄” 的关系

二维数据表
每一行称为一条记录,用来描述一个对象的信息
每一列称为一个字段,用来描述对象的一个属性

主键
数据表中的每行记录都必须是唯一的,不允许出现完全相同的记录,通过定义主键(主关键字,Promary Key)可以保证记录(实体)的唯一性键,即关键字,是关系模型中一个非常重要的元素

主键唯一标识表中的行数据,一个主键值对应一行数据,主键由一个或多个字段组成,其值具有唯一性,不允许取空值(NULL)一个表只能有一个主键;

如果一个属性集能唯一地标识表的一行而又不含有多余的属性,那么这个属性集称为候选键;
表中可以有多个候选键,但是只能有一个候选键可以选做表的主键,所有其他候选键称为备用键
例如下图,“编号”、“姓名”、“性别”、“年龄”、“编号” 都可以说是候选键,而可以定义 “编号” 为主键。

编号姓名性别年龄编号
1孙悟空234
2猪悟能242
3沙悟净263
4唐玄奘251

3.2、关系型数据库应用

关系型数据库应用举例
Oracle, MySQL12306用户信息系统
SQLServer、Sybase淘宝账号系统
lnformix、access联通手机号信息系统
DB2、FoxPRO银行用户账号系统
PostgreSQL网站用户信息系统

3.3、非关系型数据库

非关系型数据库: 存储海量数据,给与”大数据“进行分析,筛选出有价值的部分

Not Only SQL 不仅仅数据库 还可以缓存数据
键值 键就是变量名 值就是变量值
引申:redis 持久化方式
以键值存储数据,数据保存在内存中,但会定期将数据写入磁盘(持久化方式)

使用非关系型数据库存储,如果需要持久化,就可以使用redis

3.4、关系型数据库和非关系型数据库的区别

关系数据库
关系数据库结构是二维数据库表,二维表当中每个字段(列)用来描述对象的一个属性,每个记录(行)用来描述一个对象的信息(完整信息),关系数据库写到哪里也就是存储在硬盘当中
读写系统就会受到的Io限制或者瓶颈

关系型数据库最典型的数据结构是表,由二维表及其之间的联系所组成的一个数据组织

优点:

易于维护:都是使用表结构,格式一致;
使用方便:sQL语言通用,可用于复杂查询;
复杂操作:支持sQL,可用于一个表以及多个表之间非常复杂的查询。

缺点:

读写性能比较差,尤其是海量数据的高效率读写;
固定的表结构,灵活度稍欠;
高并发读写需求,传统关系型数据库来说,硬盘I/o是一个很大的瓶颈。

非关系型数据库(NoSQL)
MongoDB 、 Redis(内存数据库/缓存数据库)K-V键值对、与之类似的Memcache,K-V键值对
redis-memecache对比:
相同点:存储高热数据(在内存中高速运行)
不同点:redis可以做持久化保存,可以存储对象

非关系型数据库严格上不是一种数据库,应该是一种数据结构化存储方法的集合,可以是文档或者键值对等。

优点:

格式灵活:存储数据的格式可以是key,value形式、文档形式、图片形式等等,文档形式、图片形式等等,
使用灵活,应用场景广泛,而关系型数据库则只支持基础类型。
速度快:nosql可以使用硬盘或者随机存储器作为载体,而关系型数据库只能使用硬盘;
高扩展性;
成本低:nosql数据库部署简单,基本都是开源软件。

缺点:

不提供sql支持,学习和使用成本较高;
无事务处理;
数据结构相对复杂,复杂查询方面稍欠。
好多数据写在内存中

四、数据库管理命令

4.1、MySQL数据文件

MySQL数据库的数据文件存放在/usr/local/mysql/data目录下,每个数据库对应一个子目录,用于存储数据表文件。每个数据表对应为三个文件,扩展名分别为“.frm”、“.MYD”和“.MYI”。

MYD”文件是MyISAM存储引擎专用,存放MyISAM表的数据。每一个MyISAM表都会有一个“.MYD”文件与之对应,同样存放于所属数据库的文件夹下,和“.frm”文件在一起。

“.MYI”文件也是专属于 MyISAM 存储引擎的,主要存放 MyISAM 表的索引相关信息。对于 MyISAM 存储来说,可以被 cache 的内容主要就是来源于“.MYI”文件中。每一个MyISAM 表对应一个“.MYI”文件,存放于位置和“.frm”以及“.MYD”一样。

MyISAM 存储引擎的表在数据库中,每一个表都被存放为三个以表名命名的物理文件
(frm,myd,myi)。 每个表都有且仅有这样三个文件做为 MyISAM 存储类型的表的存储,也就是说不管这个表有多少个索引,都是存放在同一个.MYI 文件中。

另外还有“.ibd”和 ibdata 文件,这两种文件都是用来存放 Innodb 数据的,之所以有两种文件来存放 Innodb 的数据(包括索引),是因为Innodb的数据存储方式能够通过配置来决定是使用共享表空间存放存储数据,还是独享表空间存放存储数据。独享表空间存储 方式使用“.ibd”文件来存放数据,且每个表一个“.ibd”文件,文件存放在和 MyISAM 数据相同的位置。如果选用共享存储表空间来存放数据,则会使用 ibdata  文件来存放,所有表共同使用一个(或者多个,可自行配置)ibdata 文件。

4.2、MYSQL数据库的基本操作

1、登录数据库

mysql -u root -p

2、查看数据库结构

show databases;

show databases\G

3、查看数据库中包含的表

1、use 数据库; #切换进入数据库,后面可以不加;

2、show tables; #查看数据库中的表,得加;

3、show tables in mysql; #查看指定库中的表,这条命令不需要use切换数据库再去看表

4、显示数据表的结构

1、describe [数据库名]表名;

2、可缩写成:desc 表名;

5、常用的数据库类型

int用于定义整数类型的数据
float单精度浮点4字节32位
double双精度浮点8字节64位
char固定长度的字符类型
varchar可变长度的字符类型    
text文本
image图片
decimal(5,2)5个有效长度数字,小数点后面有2位

五、SQL语句

SQL语句用于维护管理数据库,包括数据查询、数据更新、访问控制、对象管理等功能。

SQL语言分类:
DDL:数据定义语言,用于创建数据库对象,如库、表、索引等
DML:数据操纵语言,用于对表中的数据进行管理,用来插入、删除和修改数据库中的数据
DQL:数据查询语言,用于从数据表中查找符合条件的数据记录
DCL:数据控制语言,用于设置或者更改数据库用户或角色权限(数据控制语句,用于控制不通数据段直接的许可和访问级别的语句,这些语句定义了数据库、表、字段、用户的访问权限和安全级别,如COMMIT、ROLLBACK、GRANT、REVOKE)

5.1、数据定义语句

DDL:用于创建数据库对象,如库、表、索引等

1、create  2、drop   3、alter

crate table 表名 (字段1 数据类型,字段2 数据类型[,...][,PRIMARY KEY (主键名)]);

##主键一般选择能代表唯一性的字段不允许取空值(NULL),一个表只能有一个主键。

 删除指定的数据表

1、use 数据库名

2、drop table 表名

3、drop table 【数据库名】,表名;

5.2、DML数据操作语言

数据操纵语句,用于对表中的数据进行管理,用来插入,删除和修改数据库中的数据

1、insert 插入

2、update 更新

3、delete 删除

INSERT INTO 表名(字段1,字段2[,...]) VALUES(字段1的值,字段2的值,...);

向数据表中插入新的数据记录

SELECT 字段名1,字段名2[,...] FROM 表名 [WHERE 条件表达式];

select * from ky37; #查看ky37表

 在数据库中删除指定的数据记录

1、delete from 表名 【where 条件表达式】

2、例:delete from ky37 where id=4;

3、select * from ky37;

5.3、DQL查询数据记录

1、select name from ky37\G     #以列表方式竖向显示

2、select * from ky37 limit 2;   #只显示头2行

3、select * from ky37 limit 2,3;   #显示第2行后的前三行

5.4、DCL数据控制语言

1、alter table 旧表名 rename 新表名;

2、例:alter table ky36 rename ky37;

show tables;

select * from ky37;

5.5、扩展表结构(增加字段)

1、alter table 表名 add address char(50)default ‘地址不详’;

2、default ‘地址不详’:表示此字段设置默认值 地址不详;可与 notnull 配合使用

3、例:alter table CLASS add address char(50)default  ‘null’

5.6、删除字段

1、alter table 表名 drop 字段名

2、例:alter table CLASS drop address;

5.7、创建临时表

临时表创建成功之后,使用SHOWTABLES命令是看不到创建的临时表的,临时表会在连接退出后被销毁。

如果在退出连接之前,也可以可执行增删改查等操作,比如使用DROP TABLE语句手动直接删除临时表。

PS:无法创建外键
CREATE TEMPORARY TABLE 表名 (字段1 数据类型,字段2 数据类型[, ...]
[, PRIMARY KEY (主键名)]);

sql 写入——》数据表中—》先把数据保存在内存中—》写入到磁盘
insert into info ——》info这张表,会先复制一份表数据到内存里面,给我们进行修改
---》敲完回车之后,确定提交了,才会写入数据表中—》再保存在磁盘里面

create table test01—》只会保存在内存中,在数据库退出连接之前的所有操作,都是在内存中进行的,不会保存在磁盘里面,退出连接后,临时表会释放掉

#int(4) zerofill:表示若数值不满4位数,则前面用"0"填充,例0001
#auto_increment:表示此字段为自增长字段,即每条记录自动递增1,默认从1开始递增;
自增长字段数据不可以重复;自增长字段必须是主键;如添加的记录数据没有指定此字段的值且
添加失败也会自动递增一次
#unique key:表示此字段唯一键约束,此字段数据不可以重复:一张表中只能有一个主键,但是一张表中可以有多个唯一键
#not null:表示此字段不允许为NULL 

克隆表
create table yyy2 like yyy;    #复制格式,通过LIKE方法,复制yyy表结构生成yyy2表
insert into yyy2 select * from yyy;      #备份内容

克隆表,将数据表的数据记录生成到新的表中(没有主键)
CREATE TABLE test02 (SELECT * from test);   #复制test 表数据到test02中
  
show create table test02\G    #获取数据表的表结构、索引等信息
SELECT * from test02;


http://www.kler.cn/a/284294.html

相关文章:

  • zabbix监控端界面时间与服务器时间不对应
  • uni-app中使用 unicloud 云开发平台③
  • 华为数通HCIA系列第5次考试-【2024-46周-周一】
  • Ue5 umg学习(一)
  • kettle开发-Day43-数据对比
  • learn-F12 Performance(性能)前端性能分析(LCP,CLS,INP)
  • 为什么我的手机卡需要快递员给激活?这到底安全吗?
  • Web攻击-XSS、CSRF、SQL注入
  • SimpleTranslationAIAgent:基于C#与LLM的翻译AI Agent
  • 国产游戏行业的技术进步与未来展望
  • Java | Leetcode Java题解之第385题迷你语法分析器
  • Linux 配置wireshark 分析thread 使用nRF-Sniffer dongle
  • kafak推送消息。
  • jenkins安装k8s插件发布服务
  • 项目中Redis常见的一些问题(缓存穿透,缓存雪崩,内存耗尽等)
  • Elasticsearch - SpringBoot 查询 es 相关示例
  • Linux Debian12安装flameshot火焰截图工具
  • 线段树维护更多类型的信息
  • c++ 分布式服务器 1
  • Linux | 进程池技术解析:利用无名管道实现并发任务处理(含实现代码)
  • NTP时间服务器是什么?功能是什么?京准电钟
  • 今日(2024年8月30日)科技新闻(本周)
  • Git之2.5版本重要特性及用法实例(五十七)
  • 《机器学习》【项目】 爬虫爬取数据、数据分词、贝叶斯算法、判断分类 <完整实战详解> (全篇完结)
  • ajax学习笔记
  • 认知杂谈42