【MySQL】MySQL数据库基础

【MySQL】MySQL数据库基础

🥕个人主页:开敲🍉

🔥所属专栏:MySQL🍋

🌼文章目录🌼

[1. 数据库基础](#1. 数据库基础)

[1.1 什么是数据库](#1.1 什么是数据库)

[1.2 主流数据库](#1.2 主流数据库)

[1.3 MySQL基本使用](#1.3 MySQL基本使用)

[1.3.1 服务器,数据库,表的关系](#1.3.1 服务器,数据库,表的关系)

[1.3.2 使用案例](#1.3.2 使用案例)

[1.4 MySQL架构](#1.4 MySQL架构)

[1.5 MySQL分类](#1.5 MySQL分类)

[1.6 存储引擎](#1.6 存储引擎)

[1.6.1 存储引擎](#1.6.1 存储引擎)

[1.6.2 查看存储引擎](#1.6.2 查看存储引擎)

1. 数据库基础
1.1 什么是数据库

数据库可以理解为用来存放数据的仓库。

存储数据用文件就可以了,为什么还要弄个数据库?

首先来看看文件存储数据的缺点:

① 文件不设置访问权限的话可以被任何人访问,存在安全隐患。

② 文件仅仅只对数据进行存储,查询和管理起来麻烦。

③ 文件在程序中控制不方便。

为了解决上面的问题,专家们设计出了一个更利于管理数据的东西------数据库,它能够更加有效地管理数据。

1.2 主流数据库

① SQL sever:微软的产品,.Net程序员的最爱,适用于中大型项目。

② Oracle:甲骨文产品,适合大型项目,复杂的业务逻辑,多用于银行系统。并发一般来说不如MySQL。

③ MySQL:世界上最受欢迎的数据库,属于甲骨文,并发性好,不适合做复杂的业务。主要用在电商,SNS,论坛。对简单的SQL处理效果好。

④ PostgreSQL :加州大学伯克利分校计算机系开发的关系型数据库,不管是私用,商用,还是学术研究使用,可以免费使用,修改和分发。

⑤SQLite: 是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。

⑥ H2: 是一个用Java开发的嵌入式数据库,它本身只是一个类库,可以直接嵌入到应用项目中。

1.3 MySQL基本使用
1.3.1 服务器,数据库,表的关系

① 所谓安装数据库服务器,只是在机器上安装了一个数据库管理系统程序,这个管理程序可以管理多个数据库,一般开发人员会针对每一个应用创建一个数据库。

② 为保存应用中实体的数据,一般会在数据库中创建多个表,以保存程序中实体的数据。

③ 数据库服务器、数据库和表的关系如下:

1.3.2 使用案例

① 创建数据库

create database 数据库名称

例:create database helloworld

② 使用数据库

use 数据库名称

例:use helloworld

③ 创建数据库表

create table 表名称

例:create table student (name varchar(32),age int,gender varchar(2))

表中内容格式:数据名称 数据类型 约束条件

例:name varchar 32

④ 表中插入数据

insert into student (id, name, gender) values ('张三','20, '男');

insert into student (id, name, gender) values ('张三','20, '男');

insert into student (id, name, gender) values ('张三','20, '男');

insert into student (id, name, gender) values ('张三','20, '男');

⑤ 查询表中数据

select * from student;

1.4 MySQL架构

MySQL 是一个可移植的数据库,几乎能在当前所有的操作系统上运行,如 Unix/Linux、Windows、Mac 和 Solaris。各种系统在底层实现方面各有不同,但是 MySQL 基本上能保证在各个平台上的物理体系结构的一致性。

1.5 MySQL分类

① DDL(data definition language):数据定义语言,用来维护存储数据的结构:

代表指令: create, drop, alter

② DML(data manipulation language):数据操纵语言,用来对数据进行操作:

代表指令: insert,delete,update

③ DCL(Data Control Language):数据控制语言,主要负责权限管理和事务:

代表指令: grant,revoke,commit

1.6 存储引擎
1.6.1 存储引擎

存储引擎是:数据库管理系统如何存储数据、如何为存储的数据建立索引和如何更新、查询数据等技术的实现方法。

MySQL的核心就是插件式存储引擎,支持多种存储引擎。

1.6.2 查看存储引擎

show engines;

创作不易,点个赞呗,蟹蟹啦~

相关推荐
小Tomkk5 分钟前
阿里云 RDS mysql 5.7 怎么 添加白名单 并链接数据库
数据库·mysql·阿里云
明月醉窗台1 小时前
qt使用笔记二:main.cpp详解
数据库·笔记·qt
沉到海底去吧Go2 小时前
【图片自动识别改名】识别图片中的文字并批量改名的工具,根据文字对图片批量改名,基于QT和腾讯OCR识别的实现方案
数据库·qt·ocr·图片识别自动改名·图片区域识别改名·pdf识别改名
老纪的技术唠嗑局2 小时前
重剑无锋,大巧不工 —— OceanBase 中的 Nest Loop Join 使用技巧分享
数据库·sql
未来之窗软件服务2 小时前
JAVASCRIPT 前端数据库-V6--仙盟数据库架构-—-—仙盟创梦IDE
数据库·数据库架构·仙盟创梦ide·东方仙盟·东方仙盟数据库
寒山李白2 小时前
MySQL复杂SQL(多表联查/子查询)详细讲解
sql·mysql·子查询·多表联查
冰橙子id2 小时前
centos7编译安装LNMP架构
mysql·nginx·架构·centos·php
玛奇玛丶3 小时前
面试官:千万级订单表新增字段怎么弄?
后端·mysql
一只爱撸猫的程序猿4 小时前
构建一个简单的智能文档问答系统实例
数据库·spring boot·aigc
nanzhuhe4 小时前
sql中group by使用场景
数据库·sql·数据挖掘