MySQL存储过程高级SQL语句总结

news2024/10/6 6:45:55

MySQL高级SQL语句(存储过程)

一、存储过程的概述

1.1 什么是存储过程

存储过程是一组为了完成特定功能的SQL语句集合。
存储过程在使用过程中是将常用或者复杂的工作预先使用SQL语句写好并用一个指定的名称存储起来,这个过程经编译和优化后存储在数据库服务器中。当需要使用该存储过程时,只需要调用它即可。存储过程在执行上比传统SQL速度更快、执行效率更高。

1.2 存储过程的有点

  1. 执行一次后,会将生成的二进制代码驻留缓冲区,提高执行效率。
  2. SQL语句加上控制语句的集合,灵活性高。
  3. 在服务器端存储,客户端调用时,降低网络负载。
  4. 可多次重复被调用,可随时修改,不影响客户端调用。
  5. 可完成所有的数据库操作,也可控制数据库的信息访问权限。

二、创建、调用和查看存储过程

2.1 创建存储过程

delimiter $$                 #将语句的结束符号从分号;临时改为两个$$(可以自定义)
create procedure proc ()     #创建存储过程,过程名为proc,不带参数
-> begin                     #过程体以关键字begin开始
-> select * from store_info; #过程体语句
-> end $$                    #过程体以关键字end结束
delimiter ;                   #将语句的结束符号恢复为分号

 示例:

delimiter $$create procedure proc01 ()-> bengin
-> create table student(id int,name char(10),age int);-> insert into student values(1,'zhangsan',18);-> insert into student values(2,'lisi',18);-> select * from student;-> end $$delimiter ;

 2.2 调用和查看存储过程

call proc;               #调用存储过程

show create procedure [数据库.]存储过程名;  #查看某个存储过程的具体信息
show create procedure proc;
show create procedure proc\G
show procedure status [like '%proc%'] \G

示例:

call proc01;   
 show create procedure proc01;
 show create procedure proc01\G       #查看存储过程的具体信息
 show procedure status like '%Proc01%'\G

 

 

 2.3 删除存储过程

#存储过程内容的修改方法是通过删除原有存储过程,之后再以相同的名称创建新的存储过程。
drop procedure if exists proc;
 #仅当存在时删除,不添加If EXISTS 时,如果指定的过程不存在,则产生一个错误。

示例:

drop procedure if exists proc01;

 

三、存储过程的参数

  • IN 输入参数: 表示调用者向过程传入值。(传入值可以是字面量或变量)
  • OUT 输出参数: 表示过程向调用者传出值。(可以返回多个值)(传出值只能是变量)
  • INOUT 输入输出参数: 既表示调用者向过程传入值,又表示过程向调用者传出值。(值只能是变量)

注意:变量名不能含有下划线。

delimiter $$create procedure proc2(in stuname char(20))  #参数为stuname,数据类型一定要与下面的where语句后字段的数据类型相同-> begin

-> select * from student where name = stuname;-> end $$delimiter ;call proc2('zhangsan');       #调用存储过程,并传入参数‘zhangsan’

 

 

 4.1 条件语句 :if-then-else … end if

delimiter $$  
create procedure proc03(in innum int)   #创建存储过程proc03,参数为innum,类型为int 
-> begin 
-> declare var int;         #定义变量var为int类型 
-> set var=innum*2;         #变量var的值等于传入的参数值乘2
-> if var>=10 then          #当var的值大于10时,id值会加1,否则减1
-> update ss set id=id+1;  
-> else
-> update ss set id=id-1;  
-> end if;  
-> end $$
delimiter ;
call proc03(8);    #调用存储过程,并传入参数8
call proc03(3);    #调用存储过程,并传入参数3

 

 4.2 循环语句 :while ···· end while

delimiter $$                   #修改默认结束符为$$
create procedure proc05()      #创建存储过程proc04
-> begin                       #过程体以关键字begin开始
-> declare var int(10);        #定义变量var为int类型
-> set var=0;                  #var的起始值为0
-> while var<6 do              #使用while循环,当var值小于6时满足条件,则向表中插入var的值
-> insert into ss values(var);  
-> set var=var+1;              #每次循环后var值自增1
-> end while;                  #结束while循环
-> end $$                      #创建存储过程结束
delimiter ;                    #重新修改默认结束符为原始的;
call proc05;                   #调用存储过程proc04

 

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

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

相关文章

Quarkus构建一个原生可执行文件

先决条件 大概15分钟 编辑器 安装GraalVM&#xff0c;并正确配置 Apache Maven 3.8.1 可以工作的容器 (Docker或者Podman) 一个 C语言工作开发环境 Quarkus应用程序代码 支持在C语言中进行原生编译 拥有一个C语言工作开发者环境意味着什么&#xff1f; 在Linux上&#xf…

华为手机恢复出厂设置后如何恢复数据

当您恢复出厂设置时&#xff0c;手机上存储的所有数据都会被清空。这是因为恢复出厂设置基本上是您从头开始设置手机的一种方式。 众所周知&#xff0c;重置手机会清除手机上的现有数据。如果这种强制删除让你丢失了重要数据&#xff0c;那么恢复出厂设置后数据还能恢复吗&…

企企通:如何利用数字化之道,赋能汽车行业供应链创新?

汽车是国民经济的支柱性企业&#xff0c;产业链长&#xff0c;涉及面广、带动性强&#xff0c;国际化程度高&#xff0c;在全球主要经济大国的产业体系中一直占据着重要地位。 我国汽车行业通过几十年的高速发展之后&#xff0c;从量变到质变&#xff0c;逐渐向低速增长的模式开…

把TeamTalk(即时通讯项目)中的线程池连接池拆出来单独测试。

研究过Teamtalk的伙伴会发现它的线程池和连接池与很多文件有关联&#xff0c; 这篇文章主要写&#xff0c;把它的线程池连接池拆出来需要用到哪些文件。 其实我本来只想测试它的连接池的&#xff0c;但发现连接池里套的有线程池&#xff0c;于是就一起拆出来了。 整个工程的树…

基于SpringBoot的社区小型图书管理系统的设计与实现

作者主页&#xff1a;Designer 小郑 作者简介&#xff1a;Java全栈软件工程师一枚&#xff0c;来自浙江宁波&#xff0c;负责开发管理公司OA项目&#xff0c;专注软件前后端开发&#xff08;Vue、SpringBoot和微信小程序&#xff09;、系统定制、远程技术指导。CSDN学院、蓝桥云…

有效操作:Ubuntu上已经安装最新node但是node -v返回的版本号确实错的;ubuntu第一次启动vue项目报npm版本错误

** 如已经安装过最新版的node话可直接跳到操作6&#xff1a; 1.查看node版本&#xff0c;没安装的请先安装&#xff1b; node -v 如果安装成功的话会返回版本号&#xff1a; 2.如果nodejs包出错需要重新安装的话&#xff0c;删除不干净会有可能出现问题&#xff0c;下面就介…

应用出海活跃,开发教程

移动应用行业在国内显现出用户增量放缓的趋势&#xff0c;多种类型的应用渗透率也渐趋饱和。随着政策支持力度的加大&#xff0c;越来越多移动应用走向了海外市场&#xff0c;拓宽用户群。 根据艾瑞咨询在《2022年移动应用出海趋势洞察白皮书》中指出&#xff0c;游戏类占出海…

开源项目-CRM客户关系管理系统

哈喽&#xff0c;大家好&#xff0c;今天给大家带来一个开源系统-CRM客户关系管理系统 主要功能包括客户管理&#xff0c;客户流失&#xff0c;销售机会&#xff0c;客户关怀等模块 系统开发环境以及版本 操作系统&#xff1a; Windows_7集成开发工具&#xff1a; Eclipse EE_…

Zabbix技术分享——snmp异常排查指南

大家好&#xff0c;我是乐乐。在IT运维中&#xff0c;难免会碰上设备snmp不通的情况&#xff0c;那么&#xff0c;当问题出现的时候&#xff0c;运维工程师该如何快速找到问题所在呢&#xff1f;下面让我们一起来看看吧&#xff01; 1&#xff0e;IP配置检查 首先检查zabbix监…

蓝牙模块芯片型号有哪些?国产还是进口?核心指标有哪些

目录 一、蓝牙模块的简介 先看看百度百科对“蓝牙模块”的定义蓝牙模块&#xff0c;是一种集成蓝牙功能的PCBA板&#xff0c;用于短距离无线通讯&#xff0c;按功能分为蓝牙数据模块和蓝牙语音模块。蓝牙模块是指集成蓝牙功能的芯片基本电路集合&#xff0c;用于无线网络通讯&…

UTONMOS链游将为GameFi游戏玩家带来更多的可能

2022年&#xff0c;全球新型冠状病毒疫情尚未彻底消弭&#xff0c;尽管少数国家的隔离措施和防疫规定已开始逐渐放宽&#xff0c;我国也已在疫情防控上估到彻底放开&#xff0c;但人们的生活却远未恢复“常态”。 近3年来&#xff0c;世界各国实施的防疫隔离和封城措施&#x…

Hive+Spark离线数仓工业项目实战--数仓设计及数据采集(2)

MR的Uber模式 目标&#xff1a;了解MR的Uber模式的配置及应用 实施 - Spark为什么要比MR要快 - MR慢 - 只有Map和Reduce阶段&#xff0c;每个阶段的结果都必须写入磁盘 - 如果要实现Map1 -> Map2 -> Reduce1 -> Reduce2 - Mapreduce1&#xff1a;Map…

完全可移植c2000控制器工程模板创建

完全可移植c2000控制器工程模板创建前言步骤创建工程库函数支撑文件拷贝寄存器支撑文件拷贝参考博文及资料前言 迄今为止只学过TI的两款c2000控制器TMS320F280049C和28335&#xff0c;并且所有代码编写都是通过写寄存器来实现的。相较于直接使用TI编写好的库函数&#xff0c;写…

Node.js--》Node环境及nvm版本管理安装及使用

目录 初识Node.js Node.js环境安装 nvm的安装 Node.js环境执行JS代码 初识Node.js Node.js是一个开源、跨平台的 JavaScript 运行时环境。其中文的官方网址为&#xff1a;Node.js官方网址 注意&#xff1a;浏览器是JavaScript的前端运行环境&#xff1b;Node.js是JavaScri…

OpManager 实时网络监控

网络是全球企业背后的基础。它在为您的员工提供行政服务以及为各大洲的客户提供服务方面发挥着关键作用。网络可帮助您将信息保存在一个集中位置 - 需要和限制所有其他入站请求的人员可以访问。那么&#xff0c;您如何提供持续的一流最终用户体验并维护快速发展的网络呢&#x…

JS面试题--ES6知识大全

ES6知识 字面量增强的写法的三种写法 ES6中对 对象字面量 进行了增强&#xff0c;称之为 Enhanced object literals&#xff08;增强对象字面量&#xff09;。 字面量的增强主要包括下面几部分&#xff1a; 属性的简写&#xff1a;Property Shorthand方法的简写&#xff1a…

测开工具:二次开发junit接口自动化框架

一&#xff1a;背景 源码地址&#xff1a;GitHub - 18713341733/AutoApi Java 接口自动化框架&#xff0c;一般就是junit与testng。这里我们讲一下junit接口自动化框架的二次开发。 1.1 我们实现了哪些功能 1、自定义了一些注解&#xff0c;用来管理case。包括case的描述、…

如何使用depcheck检查依赖?

目录 1. 你是否遇到过以下问题&#xff1a; 2. 原因 3. 解决 4. depcheck的其他功能 5.需要说明可能存在的问题 总结 1. 你是否遇到过以下问题&#xff1a; 1. GitHub上面克隆的项目&#xff0c;运行报错… 2.去一家新公司&#xff0c;用新电脑运行项目各种报错… 3.明…

有关linux中的文件IO的操作

Linux 应用编程中最需要掌握的基础就是文件 I/O的操作&#xff0c;学习过linux或者有过了解的应该都会听过一句话&#xff1a;linux中一切皆文件&#xff0c;文件是linux系统的核心设计思想。所以掌握文件的操作是很重要的。 那文件 I/O 又是什么&#xff1f;文件I/O指的是对文…

NumPy transpose 的定义与计算过程

NumPy transpose 的定义与计算过程NumPy documentation https://numpy.org/doc/stable/index.html numpy.transpose https://numpy.org/doc/stable/reference/generated/numpy.transpose.html numpy.ndarray.transpose https://numpy.org/doc/stable/reference/generated/num…