MySQL技能树学习——数据库组成

news2025/2/24 11:16:38

数据库组成:

数据库是一个组织和存储数据的系统,它由多个组件组成,这些组件共同工作以确保数据的安全、可靠和高效的存储和访问。数据库的主要组成部分包括:

  1. 数据库管理系统(DBMS): 数据库管理系统是数据库的核心组件,负责管理数据库的创建、维护、访问和控制。常见的数据库管理系统包括MySQL、Oracle、SQL Server、PostgreSQL等。

  2. 数据模型: 数据模型是描述数据在数据库中的组织方式的一种抽象表示。常见的数据模型包括层次模型、网络模型、关系模型和面向对象模型。关系模型是最常用的数据模型,它使用表、行和列来组织和表示数据。

  3. 数据库对象: 数据库对象是数据库中存储数据的基本单元。常见的数据库对象包括表、视图、索引、存储过程、触发器等。

  4. 表(Table): 表是数据库中存储数据的基本结构,它由行和列组成,每一列代表一个数据属性,每一行代表一个数据记录。

  5. 列(Column): 列是表的组成部分,每一列代表表中的一个数据属性,它定义了数据的类型、长度和约束条件。

  6. 行(Row): 行是表中的数据记录,每一行代表一个数据实体,它包含了一组相关的数据值,每个值对应表中的一个列。

  7. 索引(Index): 索引是一种数据结构,用于提高数据的检索速度。它可以加快数据库的查询操作,常见的索引类型包括单列索引、复合索引、唯一索引等。

  8. 视图(View): 视图是基于一个或多个表的查询结果集,它可以像表一样被查询,但实际上并不存储数据,而是通过查询动态生成。

  9. 存储过程(Stored Procedure): 存储过程是一组预定义的 SQL 语句集合,它们经过编译并存储在数据库中,可以被多次调用。

  10. 触发器(Trigger): 触发器是一种特殊的存储过程,它会在数据库中的特定事件发生时自动执行,常见的事件包括插入、更新和删除操作。

  11. 约束(Constraint): 约束是对表中数据进行限制和规范的规则,常见的约束类型包括主键约束、外键约束、唯一约束、检查约束等。

这些组件共同构成了数据库系统的基本架构,它们协同工作以实现数据的高效管理、存储、检索和保护。

表:

MySQL技能树学习-CSDN博客   MySQL技能树学习_mysql text长度是可变的吗-CSDN博客

视图:

   概念:

   视图可以由数据库中的一张表或者多张表生成,在结构上与数据表类似,但是视图本质上是一张虚拟表,视图中的数据也是由一张表或多张表中的数据组合而成。可以对视图中的数据进行增加、删除、修改、查看等操作,也可以对视图的结构进行修改

    在数据库中,视图不会保存数据,数据真正保存在数据表中。当对视图中的数据进行增加、删除和修改操作时,数据表中的数据会相应地发生变化;反之亦然。也就是说,不管是视图中的数据发生变化,还是数据表中的数据发生变化,另一方的数据也会相应地变化

        优点:

1.操作简单

将经常使用的查询操作定义为视图,可以使开发人员不需要关心视图对应的数据表的结构、表与表之间的关联关系,也不需要关心数据表之间的业务逻辑和查询条件,而只需要简单地操作视图即可,极大简化了开发人员对数据库的操作。

2.数据安全

MySQL根据权限将用户对数据的访问限制在某些数据的结果集上,而这些数据的结果集可以使用视图来实现。因此,可以根据权限将用户对数据的访问限制在某些视图上,而不必直接查询或操作数据表,这在一定程度上保障了数据表中数据的安全性。

3.数据独立

视图创建完成后,视图的结构就被确定了,当数据表的结构发生变化时不会影响视图的结构。当数据表的字段名称发生变化时,只需要简单地修改视图的查询语句即可,而不会影响用户对数据的查询操作。

4.适应灵活多变的需求

当业务系统的需求发生变化后,如果需要改动数据表的结构,则工作量相对较大,可以使用视图来减少改动的工作量。这种方式在实际工作中使用得比较多。

5.能够分解复杂的查询逻辑

数据库中如果存在复杂的查询逻辑,则可以将问题进行分解,创建多个视图获取数据,再将创建的多个视图结合起来,完成复杂的查询逻辑。

        语法: 
创建:
CREATE
      [OR REPLACE]
      [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]
      [DEFINER = user]
      [SQL SECURITY { DEFINER | INVOKER }]
      VIEW view_name [(column_list)]
      AS select_statement
      [WITH [CASCADED | LOCAL] CHECK OPTION]

·CREATE:新建视图。

·REPLACE:替换已经存在的视图。

·ALGORITHM:标识视图使用的算法。

·{UNDEFINED | MERGE | TEMPTABLE}:视图使用的算法。其中,UNDEFINED表示MySQL会自动选择算法;MERGE表示将引用视图的语句与视图定义进行合并;TEMPTABLE表示将视图的结果放置到临时表中,接下来使用临时表执行相应的SQL语句。

·DEFINER:定义视图的用户。

·SQL SECURITY:安全级别。DEFINER表示只有创建视图的用户才能访问视图;INVOKER表示具有相应权限的用户能够访问视图

·view_name:创建的视图名称。

·column_list:视图中包含的字段名称列表。

·select_statement:SELECT语句。

·[WITH [CASCADED | LOCAL] CHECK OPTION]:保证在视图的权限范围内更新视图。

查看:
  • SHOW TABLE语句同时显示出了当前数据库中数据表的名称和视图的名称
  • DESCRIBE/DESC view_name
  • SHOW TABLE STATUS LIKE ‘view_name’
  • SHOW CREATE VIEW 'view_name'
  • SELECT * FROM information_schema.view

        视图的信息存储到information_schema数据库下的views数据表中

更新:
结构:
  • CREATE OR REPLACE VIEW
  • ALTER
数据:

直接修改:

  • 向视图中插入数据 INSERT INTO view_category(id, t_category) VALUES (5, '水果')
  • 更新视图中的数据 UPDATE view_category SET t_category = '图书' WHERE id = 5
  • 删除视图数据 DELETE FROM view_category WHERE id = 5

间接修改:(更新数据库表中的数据)

删除:

案例:

单表:

多表: 

 存储过程和函数:

存储过程和函数不仅能够简化开发人员开发应用程序的工作量,而且对于存储过程和函数中SQL语句的变动,无须修改上层应用程序的代码,这也大大简化了后期对于应用程序维护的复杂度。

概念:

存储过程和存储函数都是一系列SQL语句的集合,这些SQL语句被封装到一起组成一个存储过程或者存储函数保存到数据库中。应用程序调用存储过程只需要通过CALL关键字并指定存储过程的名称和参数即可;同样,应用程序调用存储函数只需要通过SELECT关键字并指定存储函数的名称和参数即可

返回值(存储函数有,存储过程没有)

参数类型可以是IN(存储函数仅)、OUT和INOUT(存储过程都

应用场景(复杂业务):

   如果将用户下单时系统包含的这些行为单独编写每条SQL语句,之后根据SQL语句执行的先后顺序和结果条件,依次执行其他SQL语句不仅增加了开发应用程序的业务逻辑复杂性,而且在每个需要处理订单逻辑的地方都需要编写这些SQL语句,SQL语句的变动也会导致应用程序中业务逻辑的变动,这无疑增加了系统后期维护与升级的复杂度。

    此时,可以编写存储过程和函数,按照特定的执行顺序和结果条件,将相应的SQL语句封装成特定的业务逻辑,应用程序只需要调用编写的存储过程和函数进行相应的处理,而无须关注SQL语句实现的细节。同时,在后期应用程序的维护过程中修改了存储过程和函数内部的SQL语句,无须修改上层应用程序的业务逻辑。

优点:

1.具有良好的封装性

存储过程和函数将一系列的SQL语句进行封装,经过编译后保存到MySQL数据库中,可以供应用程序反复调用,而无须关注SQL逻辑的实现细节。

2.应用程序与SQL逻辑分离

存储过程和函数中的SQL语句发生变动时,在一定程度上无须修改上层应用程序的业务逻辑,大大简化了应用程序开发和维护的复杂度。

3.让SQL具备处理能力

存储过程和函数支持流程控制处理,能够增强SQL语句的灵活性,而且使用流程控制能够完成复杂的逻辑判断和相关的运算处理。

语法:
创建存储过程:

·CREATE PROCEDURE:创建存储过程必须使用的关键字;

·sp_name:创建存储过程时指定的存储过程名称;

·proc_parameter:创建存储过程时指定的参数列表,参数列表可以省略;

  •    [ IN | OUT | INOUT ] param_name type

·characteristic:创建存储过程时指定的对存储过程的约束;

  • ·LANGUAGE SQL:存储过程的SQL执行体部分(存储过程语法格式中的routine_body部分)是由SQL语句组成的。

    ·[NOT] DETERMINISTIC:执行当前存储过程后,得出的结果数据是否确定。其中,DETERMINISTIC表示执行当前存储过程后得出的结果数据是确定的,即对于当前存储过程来说,每次输入相同的数据时,都会得到相同的输出结果。NOT DETERMINISTIC表示执行当前存储过程后,得出的结果数据是不确定的,即对于当前存储过程来说,每次输入相同的数据时,得出的输出结果可能不同。如果没有设置执行值,则MySQL默认为NOT DETERMINISTIC

    ·{CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA}:存储过程中的子程序使用SQL语句的约束限制。其中,CONTAINS SQL表示当前存储过程的子程序包含SQL语句,但是并不包含读写数据的SQL语句;NO SQL表示当前存储过程的子程序中不包含任何SQL语句;READS SQL DATA表示当前存储过程的子程序中包含读数据的SQL语句;MODIFIES SQL DATA表示当前存储过程的子程序中包含写数据的SQL语句。如果没有设置相关的值,则MySQL默认指定值为CONTAINS SQL。

    ·SQL SECURITY {DEFINER | INVOKER}:执行当前存储过程的权限,即指明哪些用户能够执行当前存储过程。DEFINER表示只有当前存储过程的创建者或者定义者才能执行当前存储过程;INVOKER表示拥有当前存储过程的访问权限的用户能够执行当前存储过程。如果没有设置相关的值,则MySQL默认指定值为DEFINER。

    ·COMMENT 'string':表示当前存储过程的注释信息,解释说明当前存储过程的含义。

·routine_body:存储过程的SQL执行体,使用BEGIN…END来封装存储过程需要执行的SQL语句

案例

当用MySQL的命令行创建存储过程时,首先需要使用“DELIMITER $$”语句将MySQL数据库的语句结束符设置为“$$”。因为MySQL数据库默认的语句结束符为分号(;),如果不设置MySQL数据库的语句结束符,则存储过程中的SQL语句的结束符会与MySQL数据库默认的语句结束符相冲突。在创建存储过程的结尾使用“END $$”来结束存储过程。当整个存储过程创建完毕后,再使用“DELIMITER ;”语句将MySQL数据库的语句结束符恢复成默认的分号(;)。用MySQL命令行创建存储过程时,也可以使用DELIMITER语句指定其他符号为语句结束符,而不一定是“$$”符号。

 

索引和约束:

触发器:

认真学习MySQL 中的触发器_mysql触发器-CSDN博客

概念:

事先为某张表绑定好一段代码。当表中的某些内容发生改变的时候(增删改),系统自动触发代码执行。 即,触发器是基于(依赖于)表的。所有的触发器(针对数据库服务器而不是数据库)都会保存到数据库information_schema的triggers表中

类型:

三种类型:增删改–insert,delete和update(触发事件)

两种类型:前后–before 和 after(触发时间)

语法:
创建:

查看:
  • show triggers;
  • show create trigger 触发器名字;
删除:

drop trigger [数据库.]trigger_name;

局部变量:

声明:DECLARE var_name[,…] type [DEFAULT value]

赋值:SET var_name = expr 

存储引擎:

     存储引擎在MySQL底层以组件的形式提供,不同的存储引擎提供的存储机制、索引的存放方式和锁粒度等不同。

     查看:SHOW ENGINES

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

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

相关文章

node.js中path模块-路径处理,语法讲解

node中的path 模块是node.js的基础语法,实际开发中,我们通过使用 path 模块来得到绝对路径,避免因为相对路径带来的找不到资源的问题。 具体来说:Node.js 执行 JS 代码时,代码中的路径都是以终端所在文件夹出发查找相…

服务器被攻击,为什么后台任务管理器无法打开?

在服务器遭受DDoS攻击后,当后台任务管理器由于系统资源耗尽无法打开时,管理员需要依赖间接手段来进行攻击类型的判断和解决措施的实施。由于涉及真实代码可能涉及到敏感操作,这里将以概念性伪代码和示例指令的方式来说明。 判断攻击类型 步…

DHCPv4_CLIENT_ALLOCATING_04: 发送DHCPREQUEST - 头部值‘secs‘字段

测试目的: 验证客户端发送的DHCPREQUEST消息是否使用了与原始DHCPDISCOVER消息相同的’secs’字段值。 描述: 本测试用例旨在确保DHCP客户端在发送DHCPREQUEST消息时,使用了与它之前发送的DHCPDISCOVER消息相同的’secs’字段值。这是DHCP…

国产数据库的发展势不可挡

前言 新的一天又开始了,光头强强总不紧不慢地来到办公室,准备为今天一天的工作,做一个初上安排。突然,熊二直接进入办公室,说:“强总老大,昨天有一个数据库群炸了锅了,有一位姓虎的…

【LLM 论文】UPRISE:使用 prompt retriever 检索 prompt 来让 LLM 实现 zero-shot 解决 task

论文:UPRISE: Universal Prompt Retrieval for Improving Zero-Shot Evaluation ⭐⭐⭐⭐ EMNLP 2023, Microsoft Code:https://github.com/microsoft/LMOps 一、论文速读 这篇论文提出了 UPRISE,其思路是:训练一个 prompt retri…

Git可视化工具tortoisegit 的下载与使用

一、tortoisegit 介绍 TortoiseGit 是一个非常实用的版本控制工具,主要用于与 Git 版本控制系统配合使用。 它的主要特点包括: 图形化界面:提供了直观、方便的操作界面,让用户更易于理解和管理版本控制。与 Windows 资源管理器…

Flutter笔记:Widgets Easier组件库(9)使用弹窗

Flutter笔记 Widgets Easier组件库(9):使用弹窗 - 文章信息 - Author: 李俊才 (jcLee95) Visit me at CSDN: https://jclee95.blog.csdn.netMy WebSite:http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress o…

美国站群服务器的定义、功能以及在网站运营中的应用

美国站群服务器的定义、功能以及在网站运营中的应用 在当今互联网的蓬勃发展中,站群服务器已成为网站运营和SEO优化中不可或缺的重要工具之一。尤其是美国站群服务器,在全球范围内备受关注。本文将深入探讨美国站群服务器的定义、功能以及在网站运营中的…

Go实战训练之Web Server 与路由树

Server & 路由树 Server Web 核心 对于一个 Web 框架,至少要提供三个抽象: Server:代表服务器的抽象Context:表示上下文的抽象路由树 Server 从特性上来说,至少要提供三部分功能: 生命周期控制&…

基于SSM的宠物领养平台(有报告)。Javaee项目。ssm项目。

演示视频: 基于SSM的宠物领养平台(有报告)。Javaee项目。ssm项目。 项目介绍: 采用M(model)V(view)C(controller)三层体系结构,通过Spring Spri…

《自动机理论、语言和计算导论》阅读笔记:p215-p351

《自动机理论、语言和计算导论》学习第 11 天,p215-p351总结,总计 37 页。 一、技术总结 1.constrained problem 2.Fermat’s lats theorem Fermat’s Last Theorem states that no three positive integers a, b and c satisfy the equation a^n b…

【数据结构(邓俊辉)学习笔记】列表01——从向量到列表

文章目录 0.概述1. 从向量到列表1.1 从静态到动态1.2 从向量到列表1.3 从秩到位置1.4 列表 2. 接口2.1 列表节点2.1.1 ADT接口2.1.2 ListNode模板类 2.2 列表2.2.1 ADT接口2.2.2 List模板类 0.概述 学习了向量,再介绍下列表。先介绍下列表里的概念和语义&#xff0…

C++ | Leetcode C++题解之第66题加一

题目&#xff1a; 题解&#xff1a; class Solution { public:vector<int> plusOne(vector<int>& digits) {int n digits.size();for (int i n - 1; i > 0; --i) {if (digits[i] ! 9) {digits[i];for (int j i 1; j < n; j) {digits[j] 0;}return …

平平科技工作室-Python-超级玛丽

一.准备图片 放在文件夹取名为images 二.准备一些音频和文字格式 放在文件夹media 三.编写代码 import sys, os sys.path.append(os.getcwd()) # coding:UTF-8 import pygame,sys import os from pygame.locals import* import time pygame.init() # 设置一个长为1250,宽为…

Python | Leetcode Python题解之第65题有效数字

题目&#xff1a; 题解&#xff1a; from enum import Enumclass Solution:def isNumber(self, s: str) -> bool:State Enum("State", ["STATE_INITIAL","STATE_INT_SIGN","STATE_INTEGER","STATE_POINT","STATE_…

Redis-三主三从集群搭建

正式搭建之前&#xff0c;注意事项&#xff08;坑&#xff09;提前放到最开始&#xff0c;也可以出问题回来看&#xff0c; &#xff08;1&#xff09;第二步中最好将配置文件中的logfile自定义一个目录&#xff0c;以便于在第五步中启动出错的时候迅速定位错误。 &#xff0…

DS高阶:图论算法经典应用

一、最小生成树&#xff08;无向图&#xff09; 在了解最小生成树算法之前&#xff0c;我们首先要先了解以下的准则&#xff1a; 连通图中的每一棵生成树&#xff0c;都是原图的一个极大无环子图&#xff0c;即&#xff1a;从其中删去任何一条边&#xff0c;生成树就不在连通&a…

如何低成本创建个人网站?

目录 前言 网站源代码 虚拟主机或服务器 域名注册或免费二级域名 域名解析 上传源代码压缩包 添加刚刚的域名 成功搭建 失败的解决方案 结语 前言 很多小白都非常想拥有自己的网站&#xff0c;但很多人虽然有了自己的源代码但苦于不知道怎么将其变成所有人都能够访…

全自动预混料饲料生产线,轻松生产发酵饲料

随着人们对健康饮食的日益重视&#xff0c;发酵饲料机作为一种新X的养殖设备&#xff0c;逐渐受到了广大养殖户的青睐。全自动预混料饲料生产线不仅提高了饲料的营养价值&#xff0c;还大大缩短了饲料的发酵时间&#xff0c;为养殖户带来了可观的经济效益。 发酵饲料加工机械…

通过符号程序搜索提升prompt工程

原文地址&#xff1a;supercharging-prompt-engineering-via-symbolic-program-search 通过自动探索​​大量提示变体来找到更好的提示 2024 年 4 月 22 日 众所周知&#xff0c;LLMs的成功在很大程度上仍然取决于我们用正确的指导和例子来提示他们的能力。随着新一代LLMs变得越…