(保姆级教程)Mysql中索引、触发器、存储过程、存储函数的概念、作用,以及如何使用索引、存储过程,代码操作演示

讲解 MySQL 中索引、触发器、存储过程、存储函数的使用

文章目录

      • 1. 索引
        • 1.1 索引的分类
        • 1.2 索引的设计原则
        • 1.3 如何使用(create index)
      • 2. 触发器
        • 2.1 触发器的分类
        • 2.2 如何使用(create trigger)
      • 3. 存储过程
        • 3.1 如何使用(create procedure)
          • 3.1.1 存储过程主体
      • 4. 存储函数
        • 4.1 与存储过程的区别
        • 4.2 如何使用(create function)

1. 索引

  • 索引是一种特殊的数据结构。(就像书的目录一样)

  • 索引是提高数据库性能的重要方式,所有字段都可以添加索引。

    给某个字段添加索引,就相当于给这个字段添加目录,下次再通过这个字段查的时候,就会直接找到该位置,而不是从头开始查。

  • 使用索引,可以快速查询表中的记录。但索引会占用内存空间

1.1 索引的分类

1、普通索引:不需要任何限制条件的索引,可在任意数据类型上创建

2、唯一索引:添加索引的字段,该字段的值必须唯一,比如:主键索引

3、全文索引:针对文本类型。只能创建在 char、varchar、text 数据类型的字段上

实际应用: 查询数据量较大的字符串类型的字段时,使用全文索引可以提高速度。但 InnoDB (mysql默认的数据存储引擎)不支持全文索引

4、单列索引:只对应一个字段的索引

5、多列索引:在一张表的多个字段上创建一个索引

注意: 多列索引,查询时只需要使用第一个字段即可触发索引。

6、空间索引:只能建立在空间数据类型上(比如:GIS(地理信息系统),因为地理信息的数据就是空间数据,描述的是空间位置,如经纬度)

注意: InnoDB 不支持空间索引

主键自带索引,其它字段可以手动添加索引(但一般不会添加)

1.2 索引的设计原则

1、添加索引时,是出现在 where 语句中的字段,不是 select 后面要查询的字段。

select name from user where id=1; -- 给id添加,而不是给name

2、添加索引的字段,这一列的值尽量唯一,效率更高(因为本身就是通过这个值查询的,而现在有多个,还需要判断是哪个)

3、不要添加过多的索引,因为索引占用内存空间,没有用的索引也占用,所以维护成本高。

通常情况下,就用主键自带的索引

1.3 如何使用(create index)
-- 1. 添加索引:索引名可自定义,一般为:idx_添加索引的字段名
-- 方式一:
alter table 表名 add index 索引名(字段名);
-- 方式二(推荐):
create index 索引名 on 表名(字段名);

-- 2. 删除索引
-- 方式一:
alter table 表名 drop index 索引名;
-- 方式二(推荐):
drop index 索引名 on 表名;

2. 触发器

1、触发器中定义了一系列操作,在对指定的表进行 插入、更新或删除 (没有查询)的同时自动执行这些操作。触发器是不需要调用的

2、为什么有这个机制?

举个例子:因为有些时候对一个表的操作,不仅仅是单表,还有跟它关联的其它表,比如:删除一个班级的时候,你在班级表中把对应的班级删除了,但是学生你也应该进行相应的操作,因为班级都没有了,这个学生对应的班级也就没有了。所以触发器中就可以定义这些操作。

3、触发器的优点:

  • 开发更快。因为触发器是存储在数据库中的,在应用程序中不用每次都编写触发器中的操作。

    比如:不需要每次删一个班级,你就要编写对学生操作的 SQL

  • 更容易维护。定义触发器后,访问目标表会自动调用触发器。

    比如:假如关联的不是学生了,是教师,怎么办?那只需要修改触发器中的内容即可

  • 业务的全局实现。如果修改业务代码,只需要修改触发器。

    就是不需要改 Java 程序中的代码,只需要修改触发器即可

2.1 触发器的分类
  • 前置触发器:更新或插入 操作之前执行,关键字为:before
  • 后置触发器:更新、插入或删除 后执行,关键字为:after
  • before delete 触发器:删除之前 执行,关键字为:before delete
  • insted of 触发器: 对复杂的视图执行 插入、更新、删除时执行,关键字为:insted of
2.2 如何使用(create trigger)

1、创建

create trigger 触发器名(可自定义:一般为t_触发器类型操作名称_on_哪个表)
触发时刻 什么操作 on 哪个表上制定触发器 for each row 
触发器需要执行的操作

触发器需要执行的操作:如果要执行多个语句,可使用:begin 语句 end

提示:触发器需要执行的操作,这一部分肯定包含多个语句,每个语句都是以分号结尾,这时服务器处理程序的时候遇到第一个分号就会认为程序结束,这肯定不行。所以使用 delimiter 结束符号(比如:$$) 命令讲 MySQL 中的结束标志修改为其它符号。最后使用 opdelimiter ; 或者 delimiter ; 恢复即可。比如:

delimiter $$
create trigger t_afterInsert_on_tab1 
after insert on tab1 for each row
begin
	insert into tab2(name,age) values(new.name,new.age);
end$$
delimiter;

假如运行不报错,结果也符合预期,一般不需要设置。

例1: 给 tab1 表添加一条数据后,然后 tab2 表自动添加这个数据:

create trigger t_afterInsert_on_tab1 
after insert on tab1 for each row
begin
	insert into tab2(name,age) values(new.name,new.age);
end;

这样执行 insert into tab1(name,age) values('abc',23); 后,tab2 表中也有数据了。

注意:

new.字段名 用来引用新行的一列,old.字段名 用来引用更新或删除它之前的已有行的一列。

② 对于 insert,只有 new 是合法的,对于 delete,只有 old 是合法的,对于 update,new、old

都合法。

例2: 删除 tab1 表的后,然后 tab2 表也删除:

create trigger t_afterDelete_on_tabl
after delete on tab1 for each row 
begin
	delete from tab2 where tab2.id = old.id;
end;

这样执行 delete from tab1 where id=2; 后,tab2 表中对应 id=2 的数据也删除了。

2、删除触发器:drop trigger 触发器名;

3. 存储过程

在实际开发中用的比较多的一种方式

1、存储过程是一组为了完成特定功能的 SQL 的集合。经过编译后存储在数据库中,用户可以通过存储过程的名称调用(可传参)。

跟触发器有点像,但是触发器需要有一张目标表。存储过程跟 java 中的方法一样,可以根据需要调用。

2、一次编写,多次调用,避免重复编写相同的SQL,存储过程和函数(函数:跟存储过程类似)都是在数据库执行的,可以减少 java 程序和数据库之间的数据传输,提高效率。

在这里插入图片描述

3、存储过程的优点:

  • 模块化程序设计。把一些语句组装在一起。
  • 执行速度更快。如果某个操作需要执行大量的 SQL,存储过程比直接执行 SQL 效率更高(假如 SQL 重复,对于重复的 SQL,存储过程优势更为明显)
  • 更好的安全机制。对于没有权限存储过程的用户,可以通过授权的方式执行存储过程。
3.1 如何使用(create procedure)

1、创建

create procedure 存储过程名([参数,...])
存储过程主体

参数: 不加参数时,存储过程后面的括号不可省略。三部分组成:[in|out|inout] 参数名 参数类型

  • in 输入参数。可以使数据传递给一个存储过程

  • out 输出参数。当需要返回一个答案或结果的时候,存储过程使用输出参数

3.1.1 存储过程主体

存储过程主体: 指在调用存储过程的时候必须执行的语句。如果要执行多个语句,可使用:begin 语句 end

注意:存储过程主体中也有可能包含多个 SQL 语句。同理:只要运行不报错,结果也符合预期,一般不需要修改结束标志。

下面的内容只能使用在存储过程体中:

声明局部变量

在存储过程中可以声明局部变量,用来存储临时结果。语法:declare 变量名,... 变量类型 [default 默认值] ,比如:declare num int default 5; 或者 declare num int; 或者 declare str1,str2 varchar(10);

  1. 局部变量只能在 begin ... end语句中使用,而且必须在存储过程的开头。

  2. 给局部变量赋值:

    set 变量名=表达式;
    
    -- 多个
    set 变量名=表达式, 变量名=表达式,...;
    

② select into 语句

把选定的列值直接存储到变量中。如:select 姓名,专业名 into name,project

例子: 总计数据总数后并返回

create procedure countNum(out num int)
begin 
	select count(*) into num from tab1;
end;

-- 问题1:怎么调?
call countNum(@num1);
-- 其中 @num1 就是定义一个变量来接收返回的结果,@用来定义用户变量

-- 问题2:怎么查看结果?
select @num1;

③ 流程控制语句

  1. if 语句

    if 条件 then 语句
    [elseif 条件 then 语句]
    ....
    [else 语句]
    end if;
    

    例子: 根据传进来的值,选择判断后,存入表格

    create procedure addData(in target int)
    begin 
    	declare addName varchar(10);
    	-- 赋值
    	if target=1 then set addName="java";
    	elseif target=2 then set addName="sql";
    	else set addName="数据库";
    	end if;
    	-- 插入
    	insert into tab1(name) values(addName);
    end;
    

  2. case 语句。与之前的分支查询稍微不同

    case 要判断的值或表达式
    	when 与判断的值做比较的值 then 语句
    	[when 与判断的值做比较的值 then 语句]
    	[else 语句]
    end case;
    
    -- 或者(推荐)
    case
    	when 条件 then 语句
    	...
    	[else 语句]
    end case;
    
  3. 循环语句。MySQL 支持 3 中循环:while、repeat、loop。循环开始标识 和 循环结束标识 要有都有,要没有都没有,且自定义的名字要一样。

    [循环开始标识:]
    while 条件 do
    	语句
    end while [循环结束标识];
    
    =============
    [循环开始标识:]
    repeat
    	语句
    	until 条件
    end repeat [循环结束标识];
    
    =============
    [循环开始标识:]
    loop
    	语句
    end loop [循环结束标识];
    

    问题:怎么跳出循环?----> leave(类似 break)、iterate(类似 continue)比如:

    create procedure doloop()
    begin 
    	set @a=10;   -- @a就是用户变量(前面有@标识)
    	label:
    	loop
    		set @a=@a-1;
    		if @a<0 then leave label; -- 满足条件后跳出循环
    		end if;
    	end loop label; -- 要有都有
    end;
    

2、调用存储过程:call 存储过程名([参数]);

3、删除存储过程:drop procedure 存储过程名;

4. 存储函数

存储函数与存储过程非常相似

4.1 与存储过程的区别
  • 存储函数不能有输出参数,参数只能为 in(可以省略,所以存储函数的参数只有名称和类型)。
  • 不能用 call 语句来调用存储函数。而是 select 语句。
  • 存储函数必须包含一条 return 语句(也就是函数必须有返回值),而存储过程不允许包含
4.2 如何使用(create function)

1、创建

create function 存储函数名([参数,...])
	returns type
	存储函数主体

其中:returns type 声明函数返回值的数据类型,比如:

-- 通过id查询名字并返回
create function name_student(student_id int)
returns int
begin
	return(select name from tab1 where id=student_id);
end;

begin 里面的 return 就是需要返回的东西,所以将内容放到 () 里面。也可以直接 return ,比如:return true; 或者 return '123';

2、调用:select 存储函数名([参数]);

3、删除:drop function 存储函数名;

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【尚跑】2023泾阳半程马拉松144 PB完赛

1、赛事背景 来到泾阳&#xff0c;就来到了中国大地原点&#xff1b; 来到泾阳&#xff0c;就来到了陕西的“白菜心心”&#xff1b; 来到泾阳&#xff0c;就来到了具有2000多年的历史长河&#xff1b; 泾河水缓缓流&#xff0c;流过郑国渠&#xff1b; 泾河水缓缓流&…

管理类联考——英语二——备考 100 句涵盖所有词汇

全中 在海里的这个地区&#xff0c;熊猫们喜欢就着苏打碗豆喝茶。而大洋州的民兵则喜欢经过半岛&#xff0c;带着编剧本的公式上餐厅去。附件的电影院里有额外的歌剧和香蕉&#xff0c;这一时代的斑马们被外面的天线所吸引。实验室里的蟹想用它的肋骨去戳四肢象灯炮的小羊。但…

经典滑动窗口试题(一)

&#x1f4d8;北尘_&#xff1a;个人主页 &#x1f30e;个人专栏:《Linux操作系统》《经典算法试题 》《C》 《数据结构与算法》 ☀️走在路上&#xff0c;不忘来时的初心 文章目录 一、将x减到0的最小操作数1、题目讲解2、讲解算法原理3、代码实现 二、无重复的最长子串1、题…

String 、StringBuffer 和 StringBuilder 的区别?

String 使用 String 声明一个字符串的时候&#xff0c;该字符串会存放在堆中的字符串常量池中。因为在java中所有的String 都是以常量表示&#xff0c;且由 final 修饰&#xff0c;因此在线程池中它的线程是安全的 且 不可变的 。每个 String 在被创建后就不再发生任何变化。 …

【考研】数据结构(更新到循环链表)

声明&#xff1a;所有代码都可以运行&#xff0c;可以直接粘贴运行&#xff08;只有库函数没有声明&#xff09; 线性表的定义和基本操作 基本操作 定义 静态&#xff1a; #include<stdio.h> #include<stdlib.h>#define MaxSize 10//静态 typedef struct{int d…

Modbus RTU协议及modbus库函数使用

一、与Modbus TCP的区别 在一般工业场景使用modbus RTU的场景还是更多一些&#xff0c;modbus RTU基于串行协议进行收发数据&#xff0c;包括RS232/485等工业总线协议。 与modbus TCP不同的是RTU没有报文头MBAP字段&#xff0c;但是在尾部增加了两个CRC检验字节&#xff08;CRC…

关键字const的修饰(指针)

A.const修饰变量 变量是可以修改的&#xff0c;如果把变量的地址交给⼀个指针变量&#xff0c;通过指针变量的也可以修改这个变量。 但是如果我们希望⼀个变量加上⼀些限制&#xff0c;不能被修改&#xff0c;怎么做呢&#xff1f;这就是const的作⽤。 #include <stdio.h&…

Public Key Retrieval is not allowed客户端连接

使用DBeavear或navicat连接mysql服务器时&#xff0c;报错Public Key Retrieval is not allowed 原因&#xff1a; 客户端默认禁用 SSL/TLS 协议&#xff0c;客户端会使用服务器的公钥进行传输&#xff0c;默认情况下客户端不会主动去找服务器拿公钥&#xff0c;进而会出现…

gmapping仿真

文章目录 获取源码安装依赖项编译简单场景运行gmapping开启键盘控制通过launch文件来启动gmappingGmapping建图的参数设置地图的保存和加载参考 获取源码 cd ~/catkin_ws/src/ git clone https://gitcode.com/weixin_42990464/wpr_simulation.git git clone https://gitcode.c…

基于动量的梯度下降

丹尼尔林肯 (Daniel Lincoln)在Unsplash上拍摄的照片 一、说明 基于动量的梯度下降是一种梯度下降优化算法变体&#xff0c;它在更新规则中添加了动量项。动量项计算为过去梯度的移动平均值&#xff0c;过去梯度的权重由称为 Beta 的超参数控制。 这有助于解决与普通梯度下降相…

香港科技大学广州|智能制造学域博士招生宣讲会—大连理工大学专场

时间&#xff1a;2023年12月06日&#xff08;星期三&#xff09;16:00 地点&#xff1a;大连理工大学厚民楼&#xff08;马院&#xff09;422 报名链接&#xff1a;https://www.wjx.top/vm/mmukLPC.aspx# 宣讲嘉宾&#xff1a; 汤凯教授 学域主任 https://facultyprofiles.h…

2024东北师范大学计算机考研分析

24计算机考研|上岸指南 东北师范大学 信息科学与技术学院位于长春净月国家高新技术产业开发区&#xff0c;毗邻风光秀美的净月潭国家森林公园。 信息科学与技术学院由原“计算机科学与信息技术学院”和“信息与软件工程学院”于2017年根据学校事业发展需要整合形成。学院设有…

Linux加强篇001-部署Linux系统

目录 一、前言 1.1准备工具 1.2安装配置VM虚拟机 1.3安装软件 1.4系统初始化进程 1.5重置root密码 二、巩固练习 1&#xff0e;为什么建议读者在下载系统文件后先进行校验而不是直接安装呢&#xff1f; 2&#xff0e;使用虚拟机安装Linux系统时&#xff0c;为什么要先…

linux centos上安装python3.11.x详细完整教程

一. 安装步骤 注意&#xff1a; 1、安装python3.11的其他版本替换下面的版本信息即可。(如想安装3.11.5将案例中的3.11.0替换成3.11.5即可) #下载最新的软件安装包 wget https://www.python.org/ftp/python/3.11.0/Python-3.11.0.tgz#解压缩安装包 tar -xzf Python-3.11.0.tg…

机器学习之危险品车辆目标检测

危险品的运输涉及从离开仓库到由车辆运输到目的地的风险。监控事故、车辆运动动态以及车辆通过特定区域的频率对于监督车辆运输危险品的过程至关重要。 在线工具推荐&#xff1a; 三维数字孪生场景工具 - GLTF/GLB在线编辑器 - Three.js AI自动纹理化开发 - YOLO 虚幻合成数…

java.util.HashMap cannot be castto org.imeta.orm.base.BizObject

if(null !biz.get("headParallel")){biz.set("headParallel", new BizObject(biz.get("headParallel"))); } 类型给他转换一下930bip旗舰版

jQuery【回到顶部、Swiper轮播图、立即执行函数、链式调用、参数重载、jQuery扩展】(六)-全面详解(学习总结---从入门到深化)

目录 回到顶部 Swiper轮播图 jQuery源码_立即执行函数 jQuery源码_链式调用 jQuery源码_参数重载 jQuery扩展 回到顶部 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compati…

SPS简单对应分析

前言&#xff1a; 本专栏参考教材为《SPSS22.0从入门到精通》&#xff0c;由于软件版本原因&#xff0c;部分内容有所改变&#xff0c;为适应软件版本的变化&#xff0c;特此创作此专栏便于大家学习。本专栏使用软件为&#xff1a;SPSS25.0 本专栏所有的数据文件请点击此链接下…

五年程序员兼职接单的肺腑之言!

不知不觉我已经参加工作&#xff0c;当一个程序员五年了&#xff0c;从一个职场菜鸟逐渐变成老油条&#xff0c;个中辛酸只有自己知道。这五年做过各种兼职接单&#xff0c;踩过不少坑&#xff0c;今天就把我在程序员接单上的一些心得体会分享给大家&#xff0c;希望能对兼职接…

【OpenCV实现图像:制作酷炫的动画效果】

文章目录 概要生成背景图添加点动画添加文本显示小结 概要 首先&#xff0c;通过导入必要的库&#xff0c;包括NumPy用于数学运算和Matplotlib库用于数据可视化。随后&#xff0c;创建图形和轴&#xff0c;初始化点的位置&#xff0c;以及编写初始化函数和更新函数。 初始化函…
最新文章