《MySQL 简易速速上手小册》第9章:高级 MySQL 特性和技巧(2024 最新版)

在这里插入图片描述

文章目录

  • 9.1 使用存储过程和触发器
    • 9.1.1 基础知识
    • 9.1.2 重点案例:使用 Python 调用存储过程实现用户注册
    • 9.1.3 拓展案例 1:利用触发器自动记录数据更改历史
    • 9.1.4 拓展案例 2:使用 Python 和触发器实现数据完整性检查
  • 9.2 管理和查询 JSON 数据
    • 9.2.1 基础知识
    • 9.2.2 重点案例:使用 Python 将数据存储为 JSON 格式
    • 9.2.3 拓展案例 1:查询 JSON 数据
    • 9.2.4 拓展案例 2:更新 JSON 数据
  • 9.3 使用视图和临时表
    • 9.3.1 基础知识
    • 9.3.2 重点案例:使用 Python 和视图简化数据访问
    • 9.3.3 拓展案例 1:使用 Python 和临时表处理复杂数据
    • 9.3.4 拓展案例 2:使用视图和 Python 实现数据权限管理

9.1 使用存储过程和触发器

探索存储过程和触发器的魔法世界

在MySQL的奇妙世界里,存储过程和触发器是那些默默守护着数据完整性和自动化工作流的守护者。它们就像是被赋予了特殊魔法的仪式和符咒,一旦被唤醒,就能自动执行一系列复杂的任务。

9.1.1 基础知识

  • 存储过程:是一组为了完成特定功能的SQL语句集,存储在数据库中,可以通过简单的调用来执行。它们就像是预先编排好的魔法组合,旨在提高数据处理的效率和一致性。
  • 触发器:是数据库中的一种特殊类型的存储过程,它会在数据表上发生特定事件(如INSERT、UPDATE、DELETE)时自动执行。触发器就像是那些守护着秘密入口的看门人,一旦有人触发了门铃,它们就会按照既定的规则行动。

9.1.2 重点案例:使用 Python 调用存储过程实现用户注册

假设你正在开发一个网站,需要实现一个用户注册的功能,这个功能需要通过调用存储过程来完成。

步骤

  1. 首先,在MySQL中创建一个存储过程create_user

    DELIMITER $$
    CREATE PROCEDURE create_user(IN username VARCHAR(255), IN password VARCHAR(255))
    BEGININSERT INTO users(username, password) VALUES(username, password);
    END$$
    DELIMITER ;
    
  2. 使用Python调用这个存储过程。

    import mysql.connectorconn = mysql.connector.connect(user='user', password='password', host='localhost', database='testdb')
    cursor = conn.cursor()
    cursor.callproc('create_user', ['new_user', 'password123'])
    conn.commit()
    cursor.close()
    conn.close()
    print("User registered successfully.")
    

9.1.3 拓展案例 1:利用触发器自动记录数据更改历史

为了追踪users表的更改历史,你可以创建一个触发器,在每次用户信息更新时自动记录更改。

DELIMITER $$
CREATE TRIGGER before_user_update
BEFORE UPDATE ON users
FOR EACH ROW
BEGININSERT INTO users_history(user_id, username, action)VALUES(OLD.id, OLD.username, 'UPDATE');
END$$
DELIMITER ;

9.1.4 拓展案例 2:使用 Python 和触发器实现数据完整性检查

假设你要确保orders表中的order_amount字段总是正数,你可以创建一个触发器来实现这一规则,并使用Python插入数据测试它。

DELIMITER $$
CREATE TRIGGER check_order_amount
BEFORE INSERT ON orders
FOR EACH ROW
BEGINIF NEW.order_amount <= 0 THENSIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Order amount must be positive';END IF;
END$$
DELIMITER ;
import mysql.connector
from mysql.connector import Errortry:conn = mysql.connector.connect(user='user', password='password', host='localhost', database='testdb')cursor = conn.cursor()cursor.execute("INSERT INTO orders (order_id, order_amount) VALUES (%s, %s)", (1, -100))conn.commit()
except Error as e:print(f"Error: {e}")
finally:if conn.is_connected():cursor.close()conn.close()

通过上述案例,你已经学会了如何在MySQL中利用存储过程和触发器来自动化和简化复杂的数据操作,并通过Python来与这些强大的工具互动。这些高级特性能够帮助你构建更加健壮、高效的应用,同时保证数据的一致性和完整性。

在这里插入图片描述


9.2 管理和查询 JSON 数据

在MySQL的宝库中,JSON数据类型是一颗璀璨的宝石,它允许你以非常灵活的格式存储和查询结构化数据。从5.7版本开始,MySQL加入了对JSON数据类型的支持,让你能够轻松地在关系数据库中处理非关系型数据。

9.2.1 基础知识

  • JSON数据类型:MySQL中的JSON是一种格式良好的字符串,能够存储复杂的数据对象和数组。
  • 函数和操作符:MySQL提供了一系列的函数和操作符来创建、查询和修改JSON文档,如JSON_EXTRACT()JSON_SET()等。
  • 索引:你可以在JSON列上创建虚拟列,并在这些虚拟列上建立索引,以提高查询性能。

9.2.2 重点案例:使用 Python 将数据存储为 JSON 格式

假设你正在开发一个内容管理系统,需要存储文章及其元数据,其中一些字段是可选的,这使得JSON成为理想的存储格式。

步骤

  1. 在MySQL数据库中创建一张表,其中包含一个JSON类型的列用来存储文章的元数据。

    CREATE TABLE articles (id INT AUTO_INCREMENT PRIMARY KEY,title VARCHAR(255) NOT NULL,content TEXT NOT NULL,metadata JSON
    );
    
  2. 使用Python插入一篇文章及其元数据。

    import mysql.connector
    import jsonarticle = {"title": "Exploring JSON in MySQL","content": "Here is the content...","metadata": {"author": "John Doe","keywords": ["MySQL", "JSON"],"published_date": "2021-08-01"}
    }conn = mysql.connector.connect(user='user', password='password', host='localhost', database='testdb')
    cursor = conn.cursor()
    cursor.execute("INSERT INTO articles (title, content, metadata) VALUES (%s, %s, %s)",(article["title"], article["content"], json.dumps(article["metadata"]))
    )
    conn.commit()
    cursor.close()
    conn.close()
    

9.2.3 拓展案例 1:查询 JSON 数据

现在,我们需要查询所有包含特定关键字的文章。

keyword = "MySQL"
query = f"SELECT title FROM articles WHERE JSON_CONTAINS(metadata->'$.keywords', '\"{keyword}\"')"cursor.execute(query)
for (title,) in cursor.fetchall():print(title)

9.2.4 拓展案例 2:更新 JSON 数据

某篇文章的发布日期需要更改,我们可以使用Python来更新这篇文章的元数据。

new_date = "2021-09-01"
article_id = 1
update_query = "UPDATE articles SET metadata = JSON_SET(metadata, '$.published_date', %s) WHERE id = %s"cursor.execute(update_query, (new_date, article_id))
conn.commit()

通过上述案例,你已经掌握了如何在MySQL中灵活使用JSON数据类型,并通过Python来进行高效的数据操作。无论是存储复杂的数据结构,还是进行高效的数据查询和更新,JSON都能够帮助你轻松应对,使你的数据库应用更加强大和灵活。

在这里插入图片描述


9.3 使用视图和临时表

在MySQL的魔法世界里,视图和临时表是两种强大的魔法工具。它们像是幻术师,能够让复杂的数据和查询在你眼前变得简单明了。视图可以为复杂的查询提供一个清晰的窗口,而临时表则在你需要它们时出现,用完即消失,帮助你高效地处理数据。

9.3.1 基础知识

  • 视图:是一种虚拟的表,其内容由查询定义。视图不仅可以简化复杂的查询,还能提供数据访问的层级,增强安全性。
  • 临时表:是在会话期间创建的,并在会话结束时自动销毁。它们非常适合存储临时数据,比如计算结果,或者作为复杂查询中的中间步骤。

9.3.2 重点案例:使用 Python 和视图简化数据访问

假设你正在开发一个报告系统,需要从多个表中聚合数据。为了简化查询,你决定创建一个视图。

步骤

  1. 创建视图以聚合数据。

    CREATE VIEW sales_summary AS
    SELECT product_id, SUM(quantity) AS total_quantity, SUM(quantity * price) AS total_sales
    FROM sales
    GROUP BY product_id;
    
  2. 使用Python查询这个视图。

    import mysql.connectorconn = mysql.connector.connect(user='user', password='password', host='localhost', database='testdb')
    cursor = conn.cursor()
    cursor.execute("SELECT * FROM sales_summary")
    for row in cursor.fetchall():print(row)
    cursor.close()
    conn.close()
    

9.3.3 拓展案例 1:使用 Python 和临时表处理复杂数据

在处理一项复杂的数据分析任务时,你需要创建一个临时表来存储中间结果。

conn = mysql.connector.connect(user='user', password='password', host='localhost', database='testdb')
cursor = conn.cursor()
cursor.execute("CREATE TEMPORARY TABLE temp_sales AS SELECT * FROM sales WHERE date >= '2021-01-01'")
cursor.execute("SELECT * FROM temp_sales")
for row in cursor.fetchall():print(row)
# 临时表在连接关闭时自动销毁
cursor.close()
conn.close()

9.3.4 拓展案例 2:使用视图和 Python 实现数据权限管理

假设你的应用对数据访问有着严格的权限要求,你可以使用视图来实现数据访问的安全层。

CREATE VIEW user_view AS
SELECT id, username, email FROM users WHERE active = 1;
# 假设只有特定的用户可以访问这个视图
def fetch_active_users(user_id):# 这里添加权限检查逻辑if user_id == "admin":cursor.execute("SELECT * FROM user_view")for row in cursor.fetchall():print(row)else:print("Access denied.")

通过上述案例,你已经学会了如何在MySQL中使用视图和临时表来简化数据访问和处理。这些技巧可以帮助你提高查询的效率,优化数据处理流程,同时保证数据访问的安全性和一致性。使用Python进行操作让这一切变得更加灵活和强大,无论是简化数据访问,还是处理复杂的数据分析任务,都能够轻松应对。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[网鼎杯 2020 朱雀组]phpweb

抓包发现两个参数&#xff0c;结合报文返回的warning猜测两个参数一个传函数名&#xff0c;另一个传函数参数 尝试直接system(ls /)&#xff0c;发现被过滤了 file_get_contents获取index.php的源码&#xff0c;发现可以反序列化实现RCE 这里复现的时候不知道为什么显示不全…

力扣例题----二叉树

文章目录 1. 100.相同的树2. 572. 另一颗树的子树3. 266.翻转二叉树4. LCR 175.计算二叉树的深度5. 110.平衡二叉树6. 101. 对称二叉树7. 牛客题目&#xff1a;KY11 二叉树遍历8. 102.二叉树的层序遍历9. 236.二叉树的最近公共祖先10. 105.根据前序和中序构造一棵二叉树11. 106…

python 人脸检测器

import cv2# 加载人脸检测器 关键文件 haarcascade_frontalface_default.xml face_cascade cv2.CascadeClassifier(haarcascade_frontalface_default.xml)# 读取图像 分析图片 ren4.png image cv2.imread(ren4.png) gray cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)# 进行人脸…

COM初体验——新建文档并写入内容。

我想在程序里和Word交互。老师跟我说不要学COM&#xff0c;因为它已经过时了。但是我不想再把代码移植到C#上面&#xff0c;然后用VSTO——已经用了std::unordered_set&#xff01;因为我使用了Copilot&#xff0c;结合我的思考&#xff0c;写了下面的代码&#xff1a; #impor…

17.JS中的object、map和weakMap

1.object和map的区别 2.weakMap和map的区别 &#xff08;1&#xff09;Map本质上就是键值对的集合&#xff0c;但是普通的Object中的键值对中的键只能是字符串。而ES6提供的Map数据结构类似于对象&#xff0c;但是它的键不限制范围&#xff0c;可以是任意类型&#xff0c;是一…

【C++】友元、内部类和匿名对象

&#x1f497;个人主页&#x1f497; ⭐个人专栏——C学习⭐ &#x1f4ab;点击关注&#x1f929;一起学习C语言&#x1f4af;&#x1f4ab; 目录 1. 友元 1.1 友元函数 1.2 友元类 2. 内部类 2.1 成员内部类 2.2 局部内部类 3. 匿名对象 3.1 基本概念 3.1 隐式转换 1…

【Spring原理进阶】SpringMVC调用链+JSP模板应用讲解

&#x1f389;&#x1f389;欢迎光临&#x1f389;&#x1f389; &#x1f3c5;我是苏泽&#xff0c;一位对技术充满热情的探索者和分享者。&#x1f680;&#x1f680; &#x1f31f;特别推荐给大家我的最新专栏《Spring 狂野之旅&#xff1a;底层原理高级进阶》 &#x1f680…

机器学习入门--循环神经网络原理与实践

循环神经网络 循环神经网络&#xff08;RNN&#xff09;是一种在序列数据上表现出色的人工神经网络。相比于传统前馈神经网络&#xff0c;RNN更加适合处理时间序列数据&#xff0c;如音频信号、自然语言和股票价格等。本文将介绍RNN的基本数学原理、使用PyTorch和Scikit-Learn…

PLC_博图系列☞FBD

PLC_博图系列☞FBD 文章目录 PLC_博图系列☞FBD背景介绍FBD优势局限性 FBD 元素 关键字&#xff1a; PLC、 西门子、 博图、 Siemens 、 FBD 背景介绍 这是一篇关于PLC编程的文章&#xff0c;特别是关于西门子的博图软件。我并不是专业的PLC编程人员&#xff0c;也不懂电路…

深度学习之梯度下降算法

梯度下降算法 梯度下降算法数学公式结果 梯度下降算法存在的问题随机梯度下降算法 梯度下降算法 数学公式 这里案例是用梯度下降算法&#xff0c;来计算 y w * x 先计算出梯度&#xff0c;再进行梯度的更新 import numpy as np import matplotlib.pyplot as pltx_data [1.0,…

心理辅导|高校心理教育辅导系统|基于Springboot的高校心理教育辅导系统设计与实现(源码+数据库+文档)

高校心理教育辅导系统目录 目录 基于Springboot的高校心理教育辅导系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、学生功能模块的实现 &#xff08;1&#xff09;学生登录界面 &#xff08;2&#xff09;留言反馈界面 &#xff08;3&#xff09;试卷列表界…

2.7日学习打卡----初学RabbitMQ(二)

2.7日学习打卡 目录&#xff1a; 2.7日学习打卡一. RabbitMQ 简单模式![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/42009c68e078440797c3183ffda6955d.png)生产者代码实现消费者代码实现 二. RabbitMQ 工作队列模式生产者代码实现消费者代码实现 三. RabbitMQ 发…

【天衍系列 04】深入理解Flink的ElasticsearchSink组件:实时数据流如何无缝地流向Elasticsearch

文章目录 01 Elasticsearch Sink 基础概念02 Elasticsearch Sink 工作原理03 Elasticsearch Sink 核心组件04 Elasticsearch Sink 配置参数05 Elasticsearch Sink 依赖管理06 Elasticsearch Sink 初阶实战07 Elasticsearch Sink 进阶实战7.1 包结构 & 项目配置项目配置appl…

《杨绛传:生活不易,保持优雅》读书摘录

目录 书简介 作者成就 书中内容摘录 良好的家世背景&#xff0c;书香门第为求学打基础 求学相关 念大学 清华研究生 自费英国留学 法国留学自学文学 战乱时期回国 当校长 当小学老师 创造话剧 支持钱锺书写《围城》 出任震旦女子文理学院的教授 接受清华大学的…

【AIGC】Stable Diffusion的ControlNet参数入门

Stable Diffusion 中的 ControlNet 是一种用于控制图像生成过程的技术&#xff0c;它可以指导模型生成特定风格、内容或属性的图像。下面是关于 ControlNet 的界面参数的详细解释&#xff1a; 低显存模式 是一种在深度学习任务中用于处理显存受限设备的技术。在这种模式下&am…

【AIGC】Stable Diffusion的模型入门

下载好相关模型文件后&#xff0c;直接放入Stable Diffusion相关目录即可使用&#xff0c;Stable Diffusion 模型就是我们日常所说的大模型&#xff0c;下载后放入**\webui\models\Stable-diffusion**目录&#xff0c;界面上就会展示相应的模型选项&#xff0c;如下图所示。作者…

【C++】 为什么多继承子类重写的父类的虚函数地址不同?『 多态调用汇编剖析』

&#x1f440;樊梓慕&#xff1a;个人主页 &#x1f3a5;个人专栏&#xff1a;《C语言》《数据结构》《蓝桥杯试题》《LeetCode刷题笔记》《实训项目》《C》《Linux》《算法》 &#x1f31d;每一个不曾起舞的日子&#xff0c;都是对生命的辜负 前言 本篇文章主要是为了解答有…

Pytest测试技巧之Fixture:模块化管理测试数据

在 Pytest 测试中&#xff0c;有效管理测试数据是提高测试质量和可维护性的关键。本文将深入探讨 Pytest 中的 Fixture&#xff0c;特别是如何利用 Fixture 实现测试数据的模块化管理&#xff0c;以提高测试用例的清晰度和可复用性。 什么是Fixture&#xff1f; 在 Pytest 中&a…

华为问界M9:领跑未来智能交通的自动驾驶黑科技

华为问界M9是一款高端电动汽车&#xff0c;其自动驾驶技术是该车型的重要卖点之一。华为在问界M9上采用了多种传感器和高级算法&#xff0c;实现了在不同场景下的自动驾驶功能&#xff0c;包括自动泊车、自适应巡航、车道保持、自动变道等。 华为问界M9的自动驾驶技术惊艳之处…

Linux之多线程

目录 一、进程与线程 1.1 进程的概念 1.2 线程的概念 1.3 线程的优点 1.4 线程的缺点 1.5 线程异常 1.6 线程用途 二、线程控制 2.1 POSIX线程库 2.2 创建一个新的线程 2.3 线程ID及进程地址空间布局 2.4 线程终止 2.5 线程等待 2.6 线程分离 一、进程与线程 在…