mysql二级-第10章.存储过程与存储函数

本文详细介绍了MySQL的存储过程和存储函数,包括概念、作用、变量类型、流程控制语句、创建与使用案例,强调了它们在提高代码复用、性能及数据库安全性方面的重要性。
摘要由CSDN通过智能技术生成

1.概述

定义:一组为完成某个特定功能的语句集,实质是存放在数据库上的一段代码
作用 —代码复用:通过命名一段长代码进而调用这段代码,其中这段被命名的代码叫过程;若代码有返回值return则叫函数(给我一个自变量,返回结果y=f(x)),函数可看成是特殊的过程)
优点:
1.减少网速流量:存储在服务器端进行,执行速度快
2.高性能:存储过程执行一次后,执行规划就留在高速缓冲存储器,下次用以二进制代码调用即可(计算过程在服务器中进行,只将结果返回给客户端)
3.保护数据库安全性和数据完整性+对访问数据库设置权限
在这里插入图片描述
开发分两类: 前端开发—客户端 后端开发—服务端(存储过程/函数)

2.涉及的几个概念

2.1变量

概念:指内存变量,典型代表如字段,用于临时存放数据,变量中的数据会随程序的改变而变化
分类:系统变量 用户变量 局部变量

2.1.1.系统变量

(@@变量名 系统定义的,如事件这个系统变量)

查看事件调度器是否打开
show variables like'event%';--不记得event啥了 用%通配符
select @@event_scheduler;--查看系统变量 两个@@
打开事件调度器
set global event_scheduler=1;--0 false,1 ture)

2.1.2 用户变量

(@变量名 用户自己定义)

目标:通过以下例子体会用户变量的作用
select...into...把选定的列的值存储到变量中
select avg(score) from tb_student where studentno in(select studentno from tb_student where studentname='李明');--idea:想把一长段代码/数据保存到变量中去
select avg(score) into @liming_avg from tb_student where studentno in(select studentno from tb_student where studentname='李明');--做法:在from前+into @自定义名,显示不出来,因为把数据写到了内存变量@liming_avg,得去查看内存变量
select @liming_avg;--查看内存变量的内容(没有from 因为数据在内存中,不在表中)

2.1.3 局部变量

名字由来:只能在begin…end的存储过程体中起作用(只存在于存储过程中,一旦存储过程结束就无效)
使用说明:先declare声明(同时赋予初始值)再set赋值
步骤:
1.declare先声明(声明变量名和数据类型,在存储过程体begin…end…开头处)
2.set赋值:
变量一旦声明,你就能在任何能使用会话变量、文字、列名的地方使用。
在这里插入图片描述

2.2.存储过程体

2.2.1declare 局部变量名 数据类型 [defalut value]

2.2.2set 局部变量名=值

declare 局部变量名 数据类型 [defalut value]--默认值有就写,没有则默认为null,涉及计算注意赋初始值
declare score_sum flaot default 0

set 变量名=set @user=1; 
set found=false;

2.2.3select…into…把选定列的值直接存储到变量中

select avg(score) into pro_avg from tb_score where studentno='1234567890'

2.2.4 流程控制语句

2.2.4.1顺序语句if…then…
2.2.4.2分支语句case…when…then…
2.2.4.3循环语句 while…do…end while;

2.2.5 游标

3.使用案例

3.1查看存储过程/函数

show procedure status \G;
show function status \G;
show create procedure 过程名 \G;
show create function fn_avg \G;
call 过程名(in的参数值,@a;      
MyCAT是一种开源软件,是面向企业的“大型数据库集群”。MyCAT是一个强制数据库,可以替代MySQL,并支持事务和ACID。作为企业数据库MySQL群集,MyCAT可以代替昂贵的Oracle群集。MyCAT还是一种新型的数据库,它看起来像是与内存缓存技术,NoSQL技术和HDFS大数据集成的SQL Server。作为一种新型的现代企业数据库产品,MyCAT与传统的数据库和新的分布式数据仓库相结合。总之,MyCAT是一种全新的数据库中间件。 Mycat的目标是以低成本将当前的独立数据库和应用程序平稳地迁移到云端,并解决由于数据存储和业务规模的快速增长而引起的瓶颈问题。 特性: 支持SQL92标准 遵守Mysql原生协议,跨语言,跨平台,跨数据库的通用中间件代理。 基于心跳的自动故障切换,支持读写分离,支持MySQL主从,以及galera cluster集群。 支持Galera for MySQL集群,Percona Cluster或者MariaDB cluster 基于Nio实现,有效管理线程,高并发问题。 支持数据的多片自动路由与聚合,支持sum,count,max等常用的聚合函数。 支持单库内部任意join,支持跨库2表join,甚至基于caltlet的多表join。 支持通过全局表,ER关系的分片策略,实现了高效的多表join查询。 支持多租户方案。 支持分布式事务(弱xa)。 支持全局序列号,解决分布式下的主键生成问题。 分片规则丰富,插件化开发,易于扩展。 强大的web,命令行监控。 支持前端作为mysq通用代理,后端JDBC方式支持Oracle、DB2、SQL Server、mongodb、巨杉。 支持密码加密 支持服务降级 支持IP白名单 支持SQL黑名单、sql注入攻击拦截 支持分表(1.6) 集群基于ZooKeeper管理,在线升级,扩容,智能优化,大数据处理(2.0开发版)。 优点: 1、基于阿里巴巴的开源项目Cobar,其稳定性,可靠性,出色的体系结构和性能以及许多成熟的用例使MyCAT有了良好的开端。站在巨人的肩膀上,MyCAT感到足够自信,可以走得更远。 2、MyCAT的基因整合了最好的开源项目和创新思想,使MyCAT领先于其他当前类似的开源项目,甚至超越了某些商业产品。 3、MyCAT支持强大的技术团队,该团队的参与者经验超过5年,其中包括一些高级软件工程师,架构师,DBA等。优秀的技术团队可确保Mycat的产品质量。 4、MyCAT不依赖任何商业公司。它与一些开源项目不同,后者的重要特征包含在其商业产品中,并使开源项目像装饰一样。   Mycat2 更新日志: v1.13 修复所有下推中带有错误联合的连接 修复生成的sql带有类型转换导致mysql运算不正确 修复黑客路由器损坏 修复黑客路由器响应int类型可能超出数字范围
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值