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

MySQL高级数据操作

✅作者简介:热爱Java后端开发的一名学习者,大家可以跟我一起讨论各种问题喔。
🍎个人主页:Hhzzy99
🍊个人信条:坚持就是胜利!
💞当前专栏:MySQL
🥭本文内容:深入理解MySQL高级数据操作。

MySQL高级数据操作


文章目录

  • MySQL高级数据操作
  • 前言
    • 视图的创建与使用
    • 存储过程与函数
    • 触发器的设计与应用
    • 事件调度器的使用
    • 用户定义变量与临时表
    • 总结


前言

MySQL是一个广泛使用的关系数据库管理系统。在这篇博客中,我们将探讨MySQL的高级数据操作功能。我们将讨论视图的创建和使用,存储过程和函数,触发器的设计和应用,事件调度器的使用,以及用户定义变量和临时表。每个主题都将包括代码示例,以帮助读者更好地理解和应用这些高级功能。

视图的创建与使用

视图是一个虚拟表,它的内容由查询定义。不同于普通的表,视图不包含数据,而是在查询的基础上生成数据。

创建视图的语法如下:

CREATE VIEW view_name AS
SELECT column1, column2, ...
FROM table_name
WHERE condition;

例如,假设我们有一个名为Employees的表,它包含员工的ID、姓名、职位和工资。我们可以创建一个视图,只显示工资高于50000的员工。

CREATE VIEW HighSalaryEmployees AS
SELECT EmployeeID, Name, Position
FROM Employees
WHERE Salary > 50000;

要查询视图,你可以像查询普通表一样使用SELECT语句:

SELECT * FROM HighSalaryEmployees;

存储过程与函数

存储过程是为了完成特定功能的SQL语句集,存储在数据库中,可以被多个程序或用户共享。函数是一种特殊类型的存储过程,它返回一个值。这意味着你可以在任何表达式中使用函数。

创建存储过程的语法如下:

CREATE PROCEDURE procedure_name()
BEGIN-- SQL statements
END;

例如,我们可以创建一个存储过程,用来增加员工的工资:

CREATE PROCEDURE IncreaseSalary(p_EmployeeID INT, p_Amount INT)
BEGINUPDATE EmployeesSET Salary = Salary + p_AmountWHERE EmployeeID = p_EmployeeID;
END;

要调用这个存储过程,你可以使用CALL语句:

CALL IncreaseSalary(123, 5000);

创建函数的语法如下:

CREATE FUNCTION function_name(parameters)
RETURNS data_type
BEGIN-- SQL statements
RETURN value;
END;

例如,我们可以创建一个函数,返回特定员工的工资:

CREATE FUNCTION GetSalary(p_EmployeeID INT)
RETURNS INT
BEGINDECLARE v_Salary INT;SELECT Salary INTO v_Salary FROM Employees WHERE EmployeeID = p_EmployeeID;RETURN v_Salary;
END;

要调用这个函数,你可以在任何表达式中使用它:

SELECT GetSalary(123);

触发器的设计与应用

触发器是一种特殊类型的存储过程。它在数据库表上定义,当特定的数据库事件(如插入,更新或删除)发生时,触发器将自动执行。

创建触

发器的语法如下:

CREATE TRIGGER trigger_name 
trigger_time trigger_event 
ON table_name FOR EACH ROW 
BEGIN-- SQL statements
END;

其中,trigger_time可以是BEFOREAFTERtrigger_event可以是INSERTUPDATEDELETE

例如,我们可以创建一个触发器,在每次增加员工工资时,都在SalaryHistory表中记录一条记录:

CREATE TRIGGER LogSalaryIncrease
AFTER UPDATE ON Employees
FOR EACH ROW 
BEGINIF NEW.Salary > OLD.Salary THENINSERT INTO SalaryHistory(EmployeeID, OldSalary, NewSalary, ChangeDate)VALUES(NEW.EmployeeID, OLD.Salary, NEW.Salary, NOW());END IF;
END;

当你在Employees表中更新工资时,这个触发器就会自动执行。

事件调度器的使用

事件调度器是MySQL的一项功能,允许你在指定的时间或时间间隔自动执行SQL语句或存储过程。

首先,你需要确保事件调度器已经启用。你可以通过以下命令检查:

SHOW VARIABLES LIKE 'event_scheduler';

如果事件调度器未启用,你可以通过以下命令启用它:

SET GLOBAL event_scheduler = ON;

创建事件的语法如下:

CREATE EVENT event_name 
ON SCHEDULE schedule 
DO-- SQL statements

其中,schedule可以是AT timestampEVERY interval

例如,我们可以创建一个事件,每天晚上12点自动删除所有未活跃的员工:

CREATE EVENT PurgeInactiveEmployees
ON SCHEDULE EVERY 1 DAY STARTS '2023-05-29 00:00:00'
DODELETE FROM Employees WHERE LastActiveDate < DATE_SUB(NOW(), INTERVAL 1 YEAR);

这个事件会每天自动执行,无需人工干预。

用户定义变量与临时表

MySQL支持用户定义变量,这些变量存储在用户会话中,并在会话结束时销毁。用户定义变量可以存储一个值,这个值可以在SQL语句中使用。

设置用户定义变量的语法如下:

SET @variable_name = value;

例如,我们可以设置一个变量,然后在查询中使用它:

SET @EmployeeID = 123;
SELECT * FROM Employees WHERE EmployeeID = @EmployeeID;

临时表是一种特殊类型的表,只在当前会话中存在,当会话结束时,临时表将被自动删除。

创建临时表的语法如下:

CREATE TEMPORARY TABLE temp_table_name AS 
SELECT column1, column2, ... 
FROM table_name 
WHERE condition;

例如,我们可以创建一个临时表,存储所有高薪员工的信息:

CREATE TEMPORARY TABLE TempHighSalaryEmployees AS 
SELECT * FROM Employees WHERE Salary > 50000;

要查询临时表,你可以像查询普通表一样使用SELECT语句:


```sql
SELECT * FROM TempHighSalaryEmployees;

总结

在这篇博客中,我们探讨了MySQL的高级数据操作功能,包括视图的创建和使用,存储过程和函数,触发器的设计和应用,事件调度器的使用,以及用户定义变量和临时表。每一个主题都包含了代码示例,帮助你更好地理解和应用这些功能。

虽然这些功能在初学者看来可能有些复杂,但是一旦你掌握了它们,你会发现它们是非常强大的工具,可以帮助你更有效地管理和操作数据。

我希望这篇博客对你有所帮助,如果你有任何问题或反馈,欢迎在评论区留言。在你的MySQL旅程中,祝你一切顺利!

相关文章:

MySQL高级数据操作

✅作者简介&#xff1a;热爱Java后端开发的一名学习者&#xff0c;大家可以跟我一起讨论各种问题喔。 &#x1f34e;个人主页&#xff1a;Hhzzy99 &#x1f34a;个人信条&#xff1a;坚持就是胜利&#xff01; &#x1f49e;当前专栏&#xff1a;MySQL &#x1f96d;本文内容&a…...

硬件设计电源系列文章-DCDC转换器基础知识

文章目录 概要整体架构流程技术名词解释技术细节小结 概要 提示&#xff1a;这里可以添加技术概要 本文主要接着上篇&#xff0c;上篇文章主要讲述了LDO的相关基础知识&#xff0c;本节开始分享DCDC基础知识 整体架构流程 提示&#xff1a;这里可以添加技术整体架构 以下是…...

XdsObjects .NET 8.45.1001.0 Crack

XdsObjects 是一个工具包&#xff0c;允许开发人员使用 IHE XDS 和 XDS-I 配置文件开发应用程序&#xff0c;只需花费最少的时间和精力&#xff0c;因为遵守配置文件和 ebXML 规则的所有艰苦工作都由该工具包处理。 它为所有角色提供客户端和服务器支持&#xff0c;包括&#…...

数据安全--17--数据安全管理之数据传输

本博客地址&#xff1a;https://security.blog.csdn.net/article/details/131061729 一、数据传输概述 数据传输有两个主体&#xff0c;一个是数据发送方&#xff0c;另一个是数据接收方。数据在通过不可信或者较低安全性的网络进行传输时&#xff0c;容易发生数据被窃取、伪…...

SpringSecurity实现前后端分离登录token认证详解

目录 1. SpringSecurity概述 1.1 权限框架 1.1.1 Apache Shiro 1.1.2 SpringSecurity 1.1.3 权限框架的选择 1.2 授权和认证 1.3 SpringSecurity的功能 2.SpringSecurity 实战 2.1 引入SpringSecurity 2.2 认证 2.2.1 登录校验流程 2.2.2 SpringSecurity完整流程 2.2.…...

Vue3_ElementPlus_简单增删改查(2023)

Vue3&#xff0c;Element Plus简单增删改查 代码&#xff1a;https://github.com/xiaoming12318/Vue3_ElementPlus_CRUD.git 环境&#xff1a; Visual Studio Code Node.js 16.0或更高版本&#xff0c;https://nodejs.org/en axios 快速上手&#xff1a; 如果已经有16.0及…...

vue中重写并自定义console.log

0. 背景 在vue2项目中自定义console.log并输出文件名及行、列号 1. 实现 1.1 自定义console.log export default {// 输出等级: 0-no, 1-error, 2-warning, 3-info, 4-debug, 5-loglevel: 5,// 输出模式: 0-default, 1-normal, 2-randommode: 1,// 是否输出图标hasIcon: fal…...

基于OpenCV 和 Dlib 进行头部姿态估计

写在前面 工作中遇到&#xff0c;简单整理博文内容涉及基于 OpenCV 和 Dlib头部姿态评估的简单Demo理解不足小伙伴帮忙指正 庐山烟雨浙江潮&#xff0c;未到千般恨不消。到得还来别无事&#xff0c;庐山烟雨浙江潮。 ----《庐山烟雨浙江潮》苏轼 https://github.com/LIRUILONGS…...

24个Jvm面试题总结及答案

1.什么是Java虚拟机&#xff1f;为什么Java被称作是“平台无关的编程语言”&#xff1f; Java虚拟机是一个可以执行Java字节码的虚拟机进程。Java源文件被编译成能被Java虚拟机执行的字节码文件。 Java被设计成允许应用程序可以运行在任意的平台&#xff0c;而不需要程序员为每…...

freemarker 生成前端文件

Freemarker是一种模板引擎&#xff0c;它允许我们在Java应用程序中分离视图和业务逻辑。在Freemarker中&#xff0c;List是一种非常有用的数据结构&#xff0c;它允许我们存储一组有序的元素。有时候&#xff0c;我们需要判断一个List是否为空&#xff0c;这在程序设计中有许多…...

Pycharm+pytest+allure打造高逼格的测试报告

目录 前言&#xff1a; 1、安装allure 2、安装allure-pytest 3、一个简单的用例test_simpe.py 4、在pycharm底部打开terminal 5、用allure美化报告 6、查看报告 总结&#xff1a; 前言&#xff1a; 今天分享的内容&#xff1a;在Pycharmpytest基础上使用allure打造高逼格…...

Mybatis-Plus中update更新操作用法

目录 一、前言二、update1、关于修改的4个条件构造器2、UpdateWrapper【用法示例】3、LambdaUpdateWrapper【用法示例】4、UpdateChainWrapper【 用法示例】5、LambdaUpdateChainWrapper【 用法示例】6、updateById 和 updateBatchById7、Mybatis-plus设置某个字段值为null的方…...

16道JVM面试题

1.jvm内存布局 1.程序计数器&#xff1a;当前线程正在执行的字节码的行号指示器&#xff0c;线程私有&#xff0c;唯一一个没有规定任何内存溢出错误的情况的区域。 2.Java虚拟机栈&#xff1a;线程私有&#xff0c;描述Java方法执行的内存模型&#xff0c;每个方法运行时都会…...

HttpRunner 接口自动化测试框架实战,打造高效测试流程

简介 2018年python开发者大会上&#xff0c;了解到HttpRuuner开源自动化测试框架&#xff0c;采用YAML/JSON格式管理用例&#xff0c;能录制和转换生成用例功能&#xff0c;充分做到用例与测试代码分离&#xff0c;相比excel维护测试场景数据更加简洁。在此&#xff0c;利用业…...

手写一个webpack插件(plugin)

熟悉 vue 和 react 的小伙伴们都知道&#xff0c;在执行过程中会有各种生命周期钩子&#xff0c;其实webpack也不例外&#xff0c;在使用webpack的时候&#xff0c;我们有时候需要在 webpack 构建流程中引入自定义的行为&#xff0c;这个时候就可以在 hooks 钩子中添加自己的方…...

jvm常见面试题

0x01. 内存模型以及分区&#xff0c;需要详细到每个区放什么。 栈区&#xff1a; 栈分为java虚拟机栈和本地方法栈 重点是Java虚拟机栈&#xff0c;它是线程私有的&#xff0c;生命周期与线程相同。 每个方法执行都会创建一个栈帧&#xff0c;用于存放局部变量表&#xff0…...

TF-A 项目的长期支持介绍

引流关键词:Armv8-A, Armv9-A, Cortex-A, Cortex-A12, Cortex-A15, Cortex-A17, Cortex-A32, Cortex-A34, Cortex-A35, Cortex-A5, Cortex-A510, Cortex-A53, Cortex-A55, Cortex-A57, Cortex-A65, Cortex-A65AE, Cortex-A7, Cortex-A710, Cortex-A715, Cortex-A72, Cortex-A7…...

企业电子招标采购系统源码java 版本 Spring Cloud + Spring Boot

项目说明 随着公司的快速发展&#xff0c;企业人员和经营规模不断壮大&#xff0c;公司对内部招采管理的提升提出了更高的要求。在企业里建立一个公平、公开、公正的采购环境&#xff0c;最大限度控制采购成本至关重要。符合国家电子招投标法律法规及相关规范&#xff0c;以及…...

7.Mysql 事务底层

一、事务的基础知识 mysql中的事务 分为 显式事务 和 隐式事务。 1.1 显式事务 显式事务就是我们手动开启事务,并且提交事务比如: -- 开启事务 begin; -- 执行查询语句 select *from where id = 1 for update ; -- 提交事务 commit;1.2 隐式事务 在 MySQL 中,隐式事务是…...

15.DIY可视化-拖拽设计1天搞定主流小程序-分类联动文章列表实时刷新

分类联动文章列表实时刷新 本教程均在第一节中项目启动下操作 分类联动文章列表实时刷新前言需求一:功能实现:点击首页分类,对应分类内容显示到当前页一、清空原分类界面:二. 设置选项卡三:设定展示内容字段:1.跨页面复制:文章分类组件到分类![在这里插入图片描述](https://img…...

【SpringCloud】二、服务注册发现Eureka与负载均衡Ribbon

文章目录 一、Eureka1、服务提供者与消费者2、Eureka原理分析3、搭建Eureka4、服务注册5、模拟多服务实例启动6、服务的发现 二、Ribbon1、负载均衡的原理2、源码分析3、负载均衡策略4、饥饿加载 一、Eureka 1、服务提供者与消费者 服务提供者&#xff1a;一次业务中&#xf…...

图形学实验(完整文件见上传)

CRect rect; this->GetClientRect(rect); pDC->Ellipse(rect); // DDALineView.cpp : implementation of the CDDALineView class // #include “stdafx.h” #include “DDALine.h” #include “DDALineDoc.h” #include “DDALineView.h” #ifdef _DEBUG #define new…...

Spark大数据处理学习笔记(3.2.1)掌握RDD算子

该文章主要为完成实训任务&#xff0c;详细实现过程及结果见【http://t.csdn.cn/FArNP】 文章目录 一、准备工作1.1 准备文件1. 准备本地系统文件2. 把文件上传到 1.2 启动Spark Shell1. 启动HDFS服务2. 启动Spark服务3. 启动Spark Shell 二、掌握转换算子2.1 映射算子 - map()…...

lammps初级:石墨烯、金属材料、纳米流体、热传导、多成分体系、金属、半导体材料的辐照、自建分子力场、MOFS、H2/CO2混合气体等模拟

1 LAMMPS的基础入门——初识LAMMPS是什么&#xff1f;能干什么&#xff1f;怎么用&#xff1f; 1.1 LAMMPS在win10和ubuntu系统的安装及使用 1.2 in文件结构格式 1.3 in文件基本语法&#xff1a;结合实例&#xff0c;讲解in文件常用命令 1.4 data文件格式 1.5 LAMMPS常见错误解…...

【MarkerDown】CSDN Markdown之时序图sequenceDiagram详解

CSDN Markdown之时序图sequenceDiagram详解 序列图 sequenceDiagram参与者与组参与者 participant拟人符号 actor别名 as组 box 消息(连线)激活/失活 activate/deactivate备注 Note循环 loop备选 Alt并行 par临界区 critical中断 break背景高亮 rect注释 %%转义字符的实体代码序…...

ReentrantLock实现原理-公平锁

在ReentrantLock实现原理(1)一节中&#xff0c;我们了解了ReentrantLock非公平锁的获取流程&#xff0c;在本节中我们来看下ReentrantLock公平锁的创建以及锁管理流程 创建ReentrantLock公平锁 创建公平锁代码如下&#xff1a; ReentrantLock reentrantLock new ReentrantL…...

掌握Scala数据结构(2)MAP、TUPLE、SET

一、映射 (Map) &#xff08;一&#xff09;不可变映射 1、创建不可变映射 创建不可变映射mp&#xff0c;用键->值的形式 创建不可变映射mp&#xff0c;用(键, 值)的形式 注意&#xff1a;Map是特质&#xff08;Scala里的trait&#xff0c;相当于Java里的interface&#…...

flutter:文件系统目录、文件读写

参考 参考&#xff1a;老孟 文件存储和网络请求 数据存储 Dart的 IO 库包含了文件读写的相关类&#xff0c;它属于 Dart 语法标准的一部分&#xff0c;所以通过 Dart IO 库&#xff0c;无论是 Dart VM 下的脚本还是 Flutter&#xff0c;都是通过 Dart IO 库来操作文件的。但…...

计算机提示“找不到vcruntime140.dll,无法继续执行代码可”以这样子修复

首先&#xff0c;对于那些不熟悉的人来说&#xff0c;vcruntime140.dll是一个关键文件&#xff0c;用于在Windows操作系统上运行使用C语言编写的大型应用程序。如果你正在运行或安装这样的应用程序&#xff0c;但找不到vcruntime140.dll文件&#xff0c;那么你的应用程序可能无…...

深度学习pytorch实战五:基于ResNet34迁移学习的方法图像分类篇自建花数据集图像分类(5类)超详细代码

1.数据集简介 2.模型相关知识 3.split_data.py——训练集与测试集划分 4.model.py——定义ResNet34网络模型 5.train.py——加载数据集并训练&#xff0c;训练集计算损失值loss&#xff0c;测试集计算accuracy&#xff0c;保存训练好的网络参数 6.predict.py——利用训练好的网…...

河南商丘疫情最新政策/seo是什么意思 为什么要做seo

Symantec Endpoint Protection v11.0.5002.333 简体中文企业版 【现象描述】&#xff1a;为了内网安全&#xff0c;内网可以上外网的一台服务器上面部署了网络版symantec杀毒软件&#xff0c;版本是 v11.0.5002.333 简体中文企业版&#xff1b;由它生成的客户端&#xff0c;分发…...

wordpress 雪花插件/河南疫情最新情况

cut 命令在Linux和Unix中的作用是从文件中的每一行中截取出一些部分&#xff0c;并输出到标准输出中。我们可以使用 cut 命令从一行字符串中于以字节&#xff0c;字符&#xff0c;字段&#xff08;分隔符&#xff09;等单位截取一部分内容出来。 在本文中&#xff0c;我们通过…...

wordpress布谷鸟主题/免费软文发布平台有哪些

前言我们在数据库建表时&#xff0c;经常会困扰某个字段应该选择什么数据类型&#xff0c;以及填写什么长度。选择数据类型方面一般不会有什么大问题&#xff0c;但是在填写对应的长度的时候&#xff0c;很多人就会困扰&#xff0c;对应长度填写的数字到底是什么含义&#xff0…...

永嘉县住房建设局网站/今日热点新闻视频

图1&#xff1a;来自(Bruna等人&#xff0c;ICLR&#xff0c;2014)的图&#xff0c;描绘了3D领域内的MNIST图像。虽然卷积网络很难对球面数据进行分类&#xff0c;但是图网络可以很自然地处理它。可以把它当做是一个处理工具&#xff0c;但在实际应用程序中会出现许多类似的任务…...

php 除了做网站/灰色词排名上首页

对象锁概念Java的所有对象都含有1个互斥锁&#xff0c;这个锁由JVM自动获取和释放。线程进入synchronized方法的时候获取该对象的锁&#xff0c;当然如果已经有线程获取了这个对象的锁&#xff0c;那么当前线程会等待&#xff0c;synchronized方法正常返回或者抛异常而终止&…...

网站图标按钮用什么做/八百客crm系统登录入口

1. 题目 原题链接 实现 pow(x, n) &#xff0c;即计算 x 的 n 次幂函数&#xff08;即&#xff0c;xn&#xff09;。 示例 1&#xff1a; 输入&#xff1a;x 2.00000, n 10 输出&#xff1a;1024.00000 示例 2&#xff1a; 输入&#xff1a;x 2.10000, n 3 输出&…...