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

MySQL数据库入门之视图、存储过程、触发器

一、视图:

1.1、视图是什么?怎么理解?

视图是从数据库的基本表(或者视图)导出的虚表(数据库只放定义它不实际存储数据,而是根据用户定义的SQL查询动态生成的结果集,具体数据存储在基本表中,所以基本表中的数据改变),视图数据改变,但是通过视图对数据进行更新(增、删、改)操作就有一定的限制从某种程度上来说,视图就像一个窗口,可以看到自己感兴趣的数据,视图始终是定义在基本表上的,所以对视图的所有操作最终都是向对应的基本表的操作。

1.2、视图的用处:

  • 简化操作:让用户关注自己需要的数据,基本表的数据通过定义视图变得更加清晰、简单。通过封装复杂的查询逻辑,使用户或应用程序可以像操作普通表一样操作视图。
  • 数据安全:使用户以多角度看同一数据,不同的用户类型通过定义不同的视图,让不同用户类型得到自己的数据。限制用户访问底层表的部分数据,通过视图只展示他们有权查看的信息。
  • 数据抽象:为不同的用户或应用提供统一的数据接口,即使底层数据结构发生变化,视图可以保持不变。视图一定程度上提供了数据的逻辑独立性。

二、存储过程:

2.1、存储过程是什么?怎么理解?

存储过程是一组预编译的SQL语句集合,存储在数据库中,并可通过一个名称调用。它可以接收输入参数、输出结果,并且能够包含流程控制语句(如条件判断和循环)。

举个例子,有一个数据库任务是计算某个用户的订单总金额。如果不使用存储过程,每次需要计算时,都需要手动写SQL语句去查找该用户的所有订单,然后对每个订单的金额进行求和。但如果创建一个存储过程 "CalculateOrderTotal",存储过程内部就已经包含了查找用户订单和计算总金额的所有SQL指令。下次需要这个信息时,只要简单地调用 "CalculateOrderTotal" 并告诉它用户ID,它就会返回结果,省去了每次都要写复杂查询的麻烦。

这就是存储过程的概念,它让数据库操作变得更高效、更简单,同时也增强了代码的复用性和数据的安全性。

2.2、存储过程的用处:

  • 提高效率:存储过程只需编译一次,之后每次调用都直接执行,减少了解析和编译SQL的时间。
  • 复用性:封装常用操作,减少代码重复,便于维护。
  • 增强安全性:限制直接访问基础表,通过参数化存储过程来执行操作。

三、触发器:

3.1、触发器是什么?怎么理解?

触发器是一种特殊类型的存储过程,它会在特定的数据库事件(如INSERT、UPDATE或DELETE)发生时自动执行。触发器又叫事件—条件—动作规则,当特定事件发生(如对表的增、删、查、改,事务的结束),对规则的条件进行检查,如果条件成立就执行规则中的动作,通常是一段SQL存储过程。触发器主要用于维护数据完整性、执行审计或自动执行业务逻辑。

3.2、触发器的用处:

  • 数据完整性:在数据变更前后自动检查或修改数据,确保满足业务规则。
  • 审计:自动记录数据更改的历史,便于追踪和审计。
  • 业务自动化:在数据变动时触发相关操作,比如订单状态更新后自动发送通知

http://www.lryc.cn/news/358219.html

相关文章:

  • Kafka原生API使用Java代码-生产者-分区策略-默认分区策略轮询分区策略
  • 网页中的音视频裁剪拼接合并
  • 【入门】使用sklearn实现的KNN算法:鸢尾花数据集分类预测
  • nss做题
  • ​第18章:JDK8-17新特性
  • 哈希表练习题(2024/5/29)
  • java —— 连接 MySQL 操作
  • 从 0 开始实现一个博客系统 (SSM 项目)
  • C++标准模板(STL)- C 内存管理库 - 分配并清零内存 (std::calloc)
  • 嵌入式开发面试问题总结(持续更新)
  • 意外发现openGauss兼容Oracle的几个条件表达式
  • 使用Keepalived提高吞吐量和负载均衡ip_hash.
  • 网络故障与排除(一)
  • C++之运算符重载
  • 使用springdoc-openapi-starter-webmvc-ui后访问swagger-ui/index.html 报错404
  • 深入理解计算机系统 家庭作业4.52
  • 深度学习:手撕 RNN(2)-RNN 的常见模型架构
  • 【Linux进程篇】Linux进程管理——进程创建与终止
  • Python爬虫实战(实战篇)—17获取【CSDN某一专栏】数据转为Markdown列表放入文章中
  • Go语言-big.Int
  • getContentView(mBinding.getRoot()); 会导致内存泄露吗?里面有SurfaceView ViewBinding
  • 基于transformers框架实践Bert系列6-完形填空
  • cesium绘制编辑区域
  • 数据库攻防之MySQL
  • 八国多语言微盘微交易所系统源码 单控点控 K线完好
  • 爪哇,我初学乍道
  • 【MySQL精通之路】全文搜索(5)-限制
  • 动态规划part03 Day43
  • Activity->Activity生命周期和启动模式
  • 浅谈网络安全态势感知