数据库基础

数据库基础

  • 什么是数据库
  • 主流数据库
  • 数据库的基本使用
    • 连接服务器
    • 服务器管理
    • 服务器、数据库、表之间的关系
    • 数据库基本指令
  • MySQL架构
  • SQL分类
  • 存储引擎
    • 什么是存储引擎
    • 查看存储引擎
    • 存储引擎对比

什么是数据库

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

文件保存数据有以下几个缺点:

文件的安全性问题

文件不利于数据查询和管理

文件不利于存储海量数据

文件在程序中控制不方便

一般的文件确实提供了数据的存储功能,但是文件并没有提供非常好的数据管理能力

为了更加有效的管理数据,所以就出现了数据库

mysql是一套给我们提供数据存取的服务的网络程序

数据库一般指的是,在磁盘或者内存中存储的特定结构组织的数据—将来在磁盘上存储的一套数据库方案

数据库本质:对数据内容存储的一套解决方案

数据库存储介质有磁盘和内存

在这里插入图片描述

  • mysql是数据库服务的客户端
  • mysqld是数据库服务的服务器端
  • mysql本质:基于C(mysql)S(mysqld)模式的一种网络服务

主流数据库

  • SQL Sever:微软的产品,.Net程序员的最爱,中大型项目。
  • Oracle:甲骨文产品,适合大型项目,复杂的业务逻辑,并发一般来说不如MySQL。
  • MySQL:世界上最受欢迎的数据库,属于甲骨文,并发性好,不适合做复杂的业务。主要用在电商,SNS,论坛。对简单的SQL处理效果好。
  • SQLite: 是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。

数据库的基本使用

连接服务器

mysql -h 127.0.0.1 -P 3306 -u root -p

-h:指名登陆部署了mysql服务的主机

-P:指名我们要访问的端口号

-u:知名登录用户

-p:指名需要输入密码

如果没有写 -h 127.0.0.1 默认是连接本地

如果没有写 -P 3306 默认是连接3306端口号

在这里插入图片描述

服务器管理

  • 执行win+r输入services.msc打开服务管理器
  • 通过下图左侧停止、暂停、重启动进行服务管理

在这里插入图片描述

服务器、数据库、表之间的关系

使用mysql建立一个数据库,再建立一张表结构,插入一些数据—mysql在Linux中是如何表现的?

  1. 建立数据库,本质就是Linux下的一个目录,数据库服务存放在/var/lib/mysql目录下

    在这里插入图片描述

  2. 在数据库内建立表,本质就是在Linux下创建对应的文件即可

    在这里插入图片描述

  3. 数据库本质其实也是文件!!只不过这些文件不由程序员直接操作,而是由数据库服务器帮我们进行操作

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

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

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

在这里插入图片描述

数据库基本指令

  • 创建数据库

    create database ST;
    
  • 使用数据库

    use ST;
    
  • 创建数据库表

    create table student(id int,name varchar(32),gender varchar(2)
    );
    
  • 表中插入数据

    insert into student (id, name, gender) values (1, '张三', '男');
    insert into student (id, name, gender) values (2, '李四', '女');
    insert into student (id, name, gender) values (3, '王五', '男');
    
  • 查询表中的数据

    select * from student;
    

在这里插入图片描述

MySQL架构

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

在这里插入图片描述

第一层:解决安全和连接管理问题

第二层:进行词法语法分析、sql语句优化

第三层:具体完成数据存储方案

第四层:依赖文件系统,把数据以二进制方式存到特定目录下,然后构建特定普通文件,把数据存储好

从系统来看:

  • 用户进程:第一、二、三层

  • 操作系统:第四层

从网络来看:

  • 应用层:第一、二、三层
  • 内核层:第四层

SQL分类

  • DDL【data definition language】 数据定义语言,用来维护存储数据的结构

    代表指令: create, drop, alter

  • DML【data manipulation language】 数据操纵语言,用来对数据进行操作

    代表指令: insert,delete,update

    • DML中又单独分了一个DQL,数据查询语言,代表指令: select
  • DCL【Data Control Language】 数据控制语言,主要负责权限管理和事务

    代表指令: grant,revoke

  • TCL 【Transaction Control Language】 事务控制语言,用于管理事务,控制数据操作的提交或回滚。

    代表指令:commit, rollback, savepoint,set transaction

存储引擎

什么是存储引擎

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

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

查看存储引擎

show engines;

在这里插入图片描述

存储引擎对比

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/16009.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

【论文复现】基于标签相关性的多标签学习

📝个人主页🌹:Eternity._ 🌹🌹期待您的关注 🌹🌹 ❀基于标签相关性的多标签学习 论文概述什么是多标签学习论文贡献 算法流程挖掘“主题“——提取标签相关性训练 𝑀 𝑇 …

MMCloud+JuiceFS:云端Nextflow工作流的新方案

在云计算和生物信息学领域,执行大规模计算任务时的性能与成本效率至关重要。MemVerge推出的JuiceFlow通过JuiceFS和云端Memory Machine Cloud(简称“MMCloud”)平台,为Nextflow工作流(pipeline)提供了一种高…

【Linux】 shell 学习汇总[转载]

转载地址:https://blog.csdn.net/baidu_33718858/article/details/81453835 一些平时使用过程中的知识点积累,来源都附上了博客,添加了一些自己的总结。 感触:linux命令用熟了相当提高工作效率,有时候用Python写十几行…

天云数据联手举办“科学传播沙龙”活动,探讨Sora是否会带来新的科学革命

4月18日,由北京市科协主办,北京科技记协承办,中关村创新研修学院、天云融创数据科技(北京)有限公司协办的“AIGC塑造数字内容生产新范式”科学传播沙龙在京举办,活动由北京市科协宣传文化部二级调研员、北京…

LlamaIndex+本地部署InternLM实践

1.环境配置 1.1 配置基础环境 这里以在 Intern Studio 服务器上部署 LlamaIndex 为例。 首先,打开 Intern Studio 界面,点击 创建开发机 配置开发机系统 填写 开发机名称 后,点击 选择镜像 使用 Cuda11.7-conda 镜像,然后在资源…

uni-segmented-control 分段器添加数量提示

1、 在 template 内写入 uni-segmented-control 基础写法 <uni-segmented-control :current"current" :values"items" :style-type"styleType" clickItem"onClickItem" activeColor"#81D8D0" />2、在 script 里面写…

Linux篇(用户管理命令)

目录 一、用户与用户组 1. 为什么要做用户与用户组管理 2. Linux的用户及用户组 2.1. Linux的多用户多任务 2.2. 什么是用户 2.3. 什么是用户组 2.4. 用户和用户组的关系 二、用户和用户组管理 1. 用户组管理 1.1. 用户组添加 /etc/group文件结构 1.2. 用户组修改 …

编程之路,从0开始:内存函数

Hello大家好&#xff01;很高兴我们又见面了。 给生活添点passion&#xff0c;开始今天的编程之路&#xff01; 今天我们来讲C语言中的内存函数。 目录 1、memcpy内存复制 2、memmove可重叠内存拷贝 3、memset设置字符 4、memcmp比较 1、memcpy内存复制 memcpy就是内存复制…

PyCharm 中的【控制台】和【终端】的区别

pycharm专业版-使用 PyCharm 中的【控制台】和【终端】的区别如下&#xff1a; 1.环境&#xff1a;控制台是 PyCharm 的内部环境&#xff0c; 终端 是操作系统的命令行界面。 2.功能&#xff1a;控制台可以运行 Python 代码&#xff0c;并显示执行结果&#xff1b; 终端可以…

IDEA修改注释颜色—图文教程

老的注释颜色用习惯了&#xff0c;新电脑的灰色注释不习惯&#xff0c;还是喜欢黄色哈哈哈哈&#x1f923;&#x1f923;&#x1f923; Block comment &#xff1a; 多行注释 Doc comment&#xff1a;文档注释 Line comment&#xff1a;单行注释 小伙伴们可以改自己喜欢的颜色…

C++ String(2)

reserve 这个地方要和reverse区分清楚&#xff0c;reserve是保留的意思&#xff0c;而reverse是逆置的意思 reserve函数可以预先分配内存 reserve(n)代表至少保留可以容纳n个字符的空间&#xff08;具体多大和编译器有关&#xff09; 比如reserve(100)&#xff0c;代表开10…

网络基础Linux

目录 计算机网络背景 网络发展 认识 "协议" 网络协议初识 OSI七层模型 TCP/IP五层(或四层)模型 网络传输基本流程 网络传输流程图 ​编辑 数据包封装和分用 网络中的地址管理 认识IP地址 认识MAC地址 笔记&#xff08;画的图&#xff09; 协议&#x…

干货 | WiFi 7(802.11BE)技术规范详解

1 概述 1.1 简介 当前全球有近200亿的Wi-Fi设备正在使用&#xff0c;Wi-Fi已成为生活、工作中不可或缺的一部分。在实际应用中&#xff0c;Wi-Fi协议所传输无线流量&#xff0c;已占到无线总流量的90%。海量数据快速、安全传输受益于巨量Wi-Fi设备高效、安全、可靠地工作&a…

线程的状态

目录 一、线程的所有状态 二、状态转换 三、多线程初体验 一、线程的所有状态 状态是针对当前线程调度情况所描述的&#xff0c;又因为线程是调度的基本单位&#xff0c;所以我们所谈到的状态都是线程的属性。在java里对线程的状态&#xff0c;进行了一个更细的划分。 我们可…

基于SpringBoot网上超市的设计与实现录像

基于SpringBoot网上超市的设计与实现录像 SpringBoot网上超市的设计与实现录像

认证鉴权框架SpringSecurity-3--代码集成_认证篇1(重写UserDetailsService示例)

上一篇介绍了springSecurity中常用的组件和过滤器链&#xff0c;明白了springSecurity管理认证和授权的基本过程和所用到的组件。之后几篇我们通过在Java代码集成springSecurity&#xff0c;来学习下代码上认证是如何实现的。 代码上常用的认证方式有两种&#xff0c;一种是实现…

C语言操作符终极揭秘:表达式求值秘籍

C语言中操作符详解&#xff08;终结篇&#xff09; 放在最前面的表达式求值定义&#xff08;1&#xff09; 操作数的求值&#xff08;2&#xff09; 操作符的应用&#xff08;3&#xff09;类型转换&#xff08;3.1&#xff09;隐式类型转换&#xff08;Type Promotion&#xf…

[代码审计]宏*HCM最新文件上传漏洞分析复现

如果觉得该文章有帮助的&#xff0c;麻烦师傅们可以搜索下微信公众号&#xff1a;良月安全。点个关注&#xff0c;感谢师傅们的支持。 免责声明 本博客所发布的所有内容&#xff0c;包括但不限于信息、工具、项目以及文章&#xff0c;均旨在提供学习与研究之用。所有工具安全性…

谷歌Gemini发布iOS版App,live语音聊天免费用!

大家好&#xff0c;我是木易&#xff0c;一个持续关注AI领域的互联网技术产品经理&#xff0c;国内Top2本科&#xff0c;美国Top10 CS研究生&#xff0c;MBA。我坚信AI是普通人变强的“外挂”&#xff0c;专注于分享AI全维度知识&#xff0c;包括但不限于AI科普&#xff0c;AI工…

MYSQL SQL优化总结【快速理解】

1、优化insert操作 批量插入&#xff0c;防止大量与数据库进行访问 手动控制事务&#xff0c;减少事务的频繁开启和提交。 主键顺序插入 2、优化主键 主键优化的点就是避免主键过长&#xff0c;因为如果有二级索引&#xff0c;叶子节点存储的数据时间上是主键&#xff0c;如果主…