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

news2025/1/19 2:42:50

在这里插入图片描述

文章目录

  • 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))
    BEGIN
        INSERT INTO users(username, password) VALUES(username, password);
    END$$
    DELIMITER ;
    
  2. 使用Python调用这个存储过程。

    import mysql.connector
    
    conn = 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
BEGIN
 INSERT 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
BEGIN
 IF NEW.order_amount <= 0 THEN
     SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Order amount must be positive';
 END IF;
END$$
DELIMITER ;
import mysql.connector
from mysql.connector import Error

try:
    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 json
    
    article = {
        "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.connector
    
    conn = 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.coloradmin.cn/o/1441928.html

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

相关文章

基于LLM的数据漂移和异常检测

大型语言模型 (LLM) 的最新进展被证明是许多领域的颠覆性力量&#xff08;请参阅&#xff1a;通用人工智能的火花&#xff1a;GPT-4 的早期实验&#xff09;。 和许多人一样&#xff0c;我们非常感兴趣地关注这些发展&#xff0c;并探索LLM影响数据科学和机器学习领域的工作流程…

你的立身之本是什么?

去年发生的一切&#xff0c;大到疫情、政治经济形势、行业的萎靡和震荡&#xff0c;小到身边的跳槽、裁员、公司倒闭……似乎都在告诉我们&#xff1a; 当冲击到来的时候&#xff0c;它是不会提前跟你打招呼的。 接下来的10年&#xff0c;我们所面临的不确定性&#xff0c;比起…

技术精英求职必备:Java开发工程师简历制作全指南

投简历找工作嘛&#xff0c;这事儿其实就跟相亲差不多&#xff0c;得让对方一眼就看上你。 在这场职场的‘相亲’中&#xff0c;怎样才能让你的简历脱颖而出&#xff0c;成为HR眼中的理想‘对象’呢&#xff1f;来&#xff0c;我给你支几招&#xff0c;让你的简历更吸引人。 …

windows编程-系统编程入门

1.进程线程概念&#xff08;简略版&#xff09; 1.1 进程 1.1.1 概念 我们编写的代码只是一个存储在硬盘的静态文件&#xff0c;通过编译后就会生成二进制可执行文件&#xff0c;当我们运行这个可执行文件后&#xff0c;它会被装载到内存中&#xff0c;接着 CPU 会执行程序中…

除夕快乐(前端小烟花)

家人们&#xff0c;新的一年好运常在&#xff0c;愿大家在新的一年里得偿所愿&#xff0c;发财暴富&#xff0c;愿大家找到属于自己的那个公主&#xff0c;下面就给大家展示一下给公主的烟花 前端烟花 新的一年&#xff0c;新的挑战&#xff0c;愿我们不忘初心&#xff0c;砥砺…

HarmonyOS 开发学习笔记

HarmonyOS 开发学习笔记 一、开发准备1.1、了解ArkTs语言1.2、TypeScript语法1.2.1、变量声明1.2.2、条件控制1.2.3、函数1.2.4、类和接口1.2.5、模块开发 1.3、快速入门 二、ArkUI组件2.1、Image组件2.2、Text文本显示组件2.3、TextInput文本输入框组件2.4、Button按钮组件2.5…

备战蓝桥杯---搜索(完结篇)

再看一道不完全是搜索的题&#xff1a; 解法1&#xff1a;贪心并查集&#xff1a; 把冲突事件从大到小排&#xff0c;判断是否两个在同一集合&#xff0c;在的话就返回&#xff0c;不在的话就合并。 下面是AC代码&#xff1a; #include<bits/stdc.h> using namespace …

Bee+SpringBoot稳定的Sharding、Mongodb ORM功能(同步 Maven)

Hibernate/MyBatis plus Sharding JDBC Jpa Spring data GraphQL App ORM (Android, 鸿蒙) Bee 小巧玲珑&#xff01;仅 860K, 还不到 1M, 但却是功能强大&#xff01; V2.2 (2024春节・LTS 版) 1.Javabean 实体支持继承 (配置 bee.osql.openEntityCanExtendtrue) 2. 增强批…

放飞梦想,扬帆起航——1888粉丝福利总结

目录 1.祝福 2.准备 3.抽奖 4.制作 5.添加 6.成果 7.感谢 8.福利 9.祝福 1.祝福 马上就是除夕了&#xff0c;在这里提前预祝大家春节快乐&#xff0c;小芒果在这里给大家拜年了&#xff01; 2.准备 其实很早之前我就在幻想着哪一天我的粉丝量能突破1888&#xff0c;…

Redis -- 安装客户端redis-plus-plus

目录 访问reids客户端github链接 安装git 如何安装&#xff1f; 下载/编译、安装客户端 安装过程中可能遇到的问题 访问reids客户端github链接 GitHub - sewenew/redis-plus-plus: Redis client written in CRedis client written in C. Contribute to sewenew/redis-p…

【动态规划】【C++算法】2518. 好分区的数目

作者推荐 【动态规划】【前缀和】【C算法】LCP 57. 打地鼠 本文涉及知识点 动态规划汇总 LeetCode:2518. 好分区的数目 给你一个正整数数组 nums 和一个整数 k 。 分区 的定义是&#xff1a;将数组划分成两个有序的 组 &#xff0c;并满足每个元素 恰好 存在于 某一个 组中…

【QT学习十四】 文件目录操作

目录 一、概述 二、详解 1. QFile QFile 类中的一些静态方法&#xff1a; 使用示例&#xff1a; 注意事项&#xff1a; 2. QDir 成员函数 使用实例&#xff1a; 注意事项&#xff1a; 3. QFileInfo 成员函数 使用实例 4. QTemporaryFile 成员函数 使用实例 注…

医学考试搜题答案这7款足够解决问题 #笔记#知识分享#其他

搜题软件一般都是通过识别题目内容搜索出问题的答案&#xff0c;当识别内容不正确或搜索不到答案时&#xff0c;又得重新到其他软件进行重复的操作&#xff0c;很是麻烦。所以我们可以使用专业的识别工具&#xff0c;对题目内容进行识别&#xff0c;然后把提取出来的内容单独保…

企业内部知识库管理软件的终极指南:如何选择最适合你的工具?

知识库管理软件对于希望提高客户支持和组织效率的公司来说是一个强大的工具。在数字时代&#xff0c;拥有一个可靠的知识库系统对于快速准确地满足客户需求至关重要。在当今的技术条件下&#xff0c;知识库管理软件有很多选择&#xff0c;每个企业都应该仔细评估并选择最适合自…

Visio2007下载安装教程,保姆级教程,附安装包和工具

前言 Visio是负责绘制流程图和示意图的软件&#xff0c;便于IT和商务人员就复杂信息、系统和流程进行可视化处理、分析和交流&#xff0c;可以促进对系统和流程的了解&#xff0c;深入了解复杂信息并利用这些知识做出更好的业务决策。帮助您创建具有专业外观的图表&#xff0c…

图像处理SoC的方案调研(视频编码器和DLA)

最近在公众号和粉丝交流&#xff0c;提到了图像处理SoC&#xff0c;包括的部分有CPU ISP 视频编码器 DLA axi/ahb/apb总线及外设&#xff0c;我觉得很有意思&#xff0c;值得学习和了解&#xff0c;尤其是视频编码器和DLA这两个概念。 1 视频编码器 视频编码器是一种可以…

内网穿透工具

1. nps-npc 1.1 简介 nps是一款轻量级、高性能、功能强大的内网穿透代理服务器。目前支持tcp、udp流量转发&#xff0c;可支持任何tcp、udp上层协议&#xff08;访问内网网站、本地支付接口调试、ssh访问、远程桌面&#xff0c;内网dns解析等等……&#xff09;&#xff0c…

Makefile编译原理 make的隐性规则

一.makefile 中的同名目标 下面程序怎么执行&#xff1f;为什么&#xff1f; 实验1 &#xff1a;makefile 中出现同名目标时 .PHONY : all all : echo "command-1"all : echo "command-2"VAR : testall :echo "all : $(VAR)"mhrubuntu:~/work/…

春节:当代发展及创新传承

为了解中国传统节日——春节&#xff0c;2024年2月9日&#xff0c;曲阜师范大学计算机学院“古韵新声&#xff0c;格物致‘知’”实践队队员贾宣在山东省青岛市西海岸新区的商场中进行了街头调查&#xff0c;探究春节的发展与当代意义。 春节历史悠久&#xff0c;起源于早期人…

vue-内置组件-Suspense

Suspense (实验性功能) <Suspense> 是一项实验性功能。它不一定会最终成为稳定功能&#xff0c;并且在稳定之前相关 API 也可能会发生变化。 <Suspense> 是一个内置组件&#xff0c;用来在组件树中协调对异步依赖的处理。它让我们可以在组件树上层等待下层的多个嵌…