MYSQL--存储过程操作
一:概念:
存储过程实际上对标了JAVA当中的方法,两者是相似的,同时需要注意的一点是,MYSQL仅仅在5.0版本之后才出现这种存储操作的过程;
优点:
1.存储过程能够让运行的速度变得更加迅速,仅仅只有首次进行实用的时候需要进行相应的编译,之后再次调用的时候可以直接进行实用
2.存储过程的特点:模块化,代码复用,封装。
二:分类
1.存储过程关键语句
2.变量
3.参数传递
4.分支语句
5.循环语句
6.游标
7.异常处理handler
1.存储过程关键语句:
delimiter (设置启动的标识符);
create procedure (存储过程的名称) (参数传递关键词 参数名称 参数类型);
begin
(检索代码)
end (开始设置的标识符);
delimiter ;
2.变量:
1>变量类型:
①:局部变量
②:用户变量
③:参数变量
2>变量介绍:
①:局部变量
范围:顾名思义,局部变量的作用范围比较的小,仅仅只能够作用在存储过程当中的begin--end之间进行实用,一旦超出范围进行调用,检索的时候就无法进行搜索:
关键语句:
delimiter ..;
create procedure ...()
begin
declare (局部变量名称) 局部变量的类型 [default ....(初始化)];
-- 开始对于局部变量进行赋值
set (局部变量名称) = ...;
(其他检索)
end ...;
delimiter ;
select (局部变量名称); -- 不成功,因为在存储过程begin-end之外运行
②用户变量:
范围:用户变量的作用范围有所增大,可以作用于当前的会话,也就是作用在当前互联网跟mysql的连接ing
关键语句:
TIPS:
-- 1.需要注意的一点是,对于所有的用户变量,都不需要进行声明,赋值即声明
-- 2.对于所有的用户变量,都能够在存储过程的外面进行调用
delimiter ...;
create procedure ...()
begin
set (用户变量名称) = ;
end ...;
delimiter ;
select (用户变量名称); -- 可以搜索到相应的结果
③参数变量:
参数变量又可以分为两个部分,一个是全局变量,一个是会话变量
1.全局变量:
1>范围:
对于全局变量的修改会影响到一整个的服务器,并且对于全局变量来说,在MYSQL启动的时候由服务器自动对他们进行默认初始化,这些默认值可以通过my.in这个文件进行修改
2>关键语句:
关键使用语句:global
1.查看全局变量:
select global variables(全局变量名称);
2.查看具体的全局变量
show global@@.(相应的全局变量名称);
3.修改全局变量的值
set global (全局变量名称) = new_value;
2.会话变量:
1>作用范围:
对于会话变量,会在每一次建立新的连接的时候,MYSQL会对其进行初始化,将全局变量的值赋值一份用来当作当前新建会话的会话变量
2>关键语句:
1.查看局部变量
select session variables;
2.查看具体的局部变量
select @session.(局部变量名称);
3.修改局部变量的值
set session (局部变量名称) =new_value;
TIPS: 其实两个变量大体上是一样的,仅仅只有在作用范围上不同,其他的都是一样。因此,如果两个变量都没有修改,那么全局变量跟用户变量的值是一样的,两者并没有区别;
三.参数传递:
1.类型:参数传递主要分为三个,包括有三个部分分别是in,out,inout
2.介绍:
操作:
in:让数据能够进入到存储过程当中进行查询
delimiter \\;
create procedure emp_1(in name varchar(20))
begin
select * from emp e where e.name=name; -- 第二个name代表的是传入的参数的名称
end \\;
delimiter ;
out:能够让参数进行返回使用
delimiter \\;
create procedure emp_2(in name varchar(20),out id int)
begin
select e.id into id from emp e where e.name=name; -- 第二个name代表的是传入的参数的名称
end \\;
delimiter ;
call emp_2(‘刘一’,@id);
select @id;
inout:能够对于输入的值进行修改,之后再进行返回
delimiter \\;
create procedure emp_3(inout name varchar(20))
begin
select * from emp e where e.name=name; -- 第二个name代表的是传入的参数的名称
end \\;
delimiter ;
set name='王老师';
call emp_3(name);
四:分支语句
1.分类:
分支语句主要包括有几个部分,if分支,case分支
2.
①:if分支
关键语句:
if (条件) then
查询;
elseif (条件...) then
查询:
else default(设置除了这些之外的其他操作会有什么结果)
endif;
delimiter \\;
create procedure pro-1(in single int)
begin
if single=1
-- 如果输入数字为1那么就显示所有的员工信息;
then select * from emp;
eles select '错误选项';
endif;
end \\;
delimiter ;
有关if的其他小知识:
leava 表示直接离开当前的条件判断 -- 相当于JAVA当中的break;
iterate 表示的是跳过当前的判断 -- 类似于在java当中的continue;
②case分支:
类似于JAVA当中的switch语句
语法一:
case case_value(变量名称)
when when_value then select语句
when when_value then select语句
[else default]
end case;
语法二:
case
when search_condition then select...
when search_condition then select...
[else default]
end case;
五:循环语句:
循环语句主要可以分为三大类:while , loop ,repeat
循环是一种虽然只会程序当中出现一次,但是能够运行多次的代码
1.while
while循环类似于JAVA当中的while的循环,都是先判断条件,判断正确之后,可以再执行之后的语句,否则结束循环
语句:
while(condition_value) do
循环体
end while;
加入到存储过程当中:
一:在表格当中插入数据,并且为自己控制插入多少条,设置use1存储过程
create table emp1(
id int primary key,
name varchar(20),
user varchar(20)
);
delimiter \\;
create procedure use1(in single int)
begin
declare i int default 1;
while(i<=single) do
insert into emp1 values(i,concat('user',i),'123456');
set i = i+1;
end while;
二:在表格当中插入single_0条数据,但是跳过第single_1条数据,设置use2存储过程
delimiter \\;
create procedure use2(in single_0 int,in single_1 int)
begin
decalre i int default 1;
w while(i<=single_0) do
a if(i = single_1) then
set i = i+1;
iterate a;
else
insert into emp values(i,concat('user',i),'123456');
set i = i+1;
end if;
end while;
end \\;
delimiter ;
2.repeat循环语句
repeat循环相当于之前在java当中所学习的do-while循环,需要先执行查找语句,之后再进行判断条件
语句:
[标签] repeat
循环体;
utile when_value;
end repeat[标签];
3.loop循环
loop循环不需要条件的判断,能够一直进行执行,所以,如果需要跳过循环,那么就需要使用相应的if条件判断,从而跳出这个死循环 -- 对应了java当中的while(true)循环
语法:
[循环标签] loop
循环体:
if when_value then....
elseif when_value then...
...leave [循环标签];...
end if;
end loop;
六.游标
1.介绍
游标是一种能够存储查询结果集的数据类型,在存储过程当中可以使用光标对结果进行一定的循环处理
2.使用
光标的使用包括:光标的声明,光标的打开,数值的获取,光标的关闭
-- 声明:
declare 游标名称 cursor for select_statement
-- 打开语法
open 游标名称
-- 取值语法
fetch 游标名称 into decl_name.....
-- 关闭语法
close 游标名称;
七.handler异常处理
1.介绍:
在MYSQL当中,针对一些错误机制进行处理的方法,通过HANDLER的使用,能够在MYSQL查询的过程当中避免一些错误类型的出现;
2.语法:
handler 异常处理
声明:declare (handler_action handler)
for (condition_value)
statement;
handler_action:主要包括有三大部分
1.contitue 在错误出现之后继续之后的查询
2.exit 在错误出现之后不再进行之后的查询,直接结束所有的查询
3.UNDO不建议
condition_value主要包括以下的几个部分
mysql_error_code
condition_name
SQLWARNING
NOT FOUND 未查询到相应的数据
SQLEXCEPTION SQL查询错误
同时的,如果需要使用handler句柄进行异常处理,首先需要考虑:
1.如果发现错误了,之后需要进行什么操作(condition_value)
2.这种错误是什么样的错误类型condition_value
TIPS:需要注意的一点,对于各种声明,顺序是,变量声明,游标声明,handler声明的顺序
推荐阅读
-
存储卡格式化,一篇了解正确操作和恢复方法的文章!
-
仓库管理:收货、管理、存储、调度和库存的精细操作与策略
-
什么是数据库事物?为什么需要数据库事物,事物有哪些特征?事物的隔离级别是什么?-1.什么是数据库事务? 1.事务是作为一个逻辑单元执行的一系列操作。一个逻辑工作单元必须具备四个属性,即ACID(原子性、一致性、隔离性和持久性)属性,只有这样才能成为事务: 原子性 2.事务必须是一个原子工作单元;它的数据修改要么全部执行,要么全部不执行。 一致性 3.事务完成时,所有数据必须保持一致。在相关数据库中,所有规则都必须适用于事务的修改,以保持所有数据的完整性。事务结束时,所有内部数据结构(如 B 树索引或双向链接表)必须正确无误。 隔离 4.并发事务的修改必须与其他并发事务的修改隔离。一个事务会在另一个并发事务修改之前或之后查看某一状态下的数据,而不会查看中间状态下的数据。这就是所谓的可序列化,因为它允许重新加载起始数据和重放一系列事务,从而使数据最终处于与原始事务执行时相同的状态。 持久性 5.事务完成后,它对系统的影响是永久性的。即使在系统发生故障的情况下,修改也会保留。 2. 为什么需要数据库事物,事物有哪些特征? 事物对数据库的作用是对数据进行一系列操作,要么全部成功,要么全部失败,防止出现中间状态,确保数据库中的数据始终处于正确、和谐的状态。 特征:原子性、一致性、隔离性、持久性,以及其他特征 原子性(Atomicity):所有操作在事务开始后,要么全部做完,要么全部不做,不可能停滞在中间环节。事务执行过程中出现错误时,会回滚到事务开始前的状态,所有操作就像没有发生一样。也就是说,事务是一个不可分割的整体,就像化学中的原子一样,是物质的基本单位。 一致性(Consistency):在事务开始之前和结束之后,数据库的完整性约束都没有被破坏。例如,如果 A 转钱给 B,A 不可能扣除这笔钱,但 B 却没有收到这笔钱。 隔离:在同一时间内,只允许一个事务请求相同的数据,不同事务之间没有干扰。例如,甲正在从一张银行卡上取款,在甲取款过程结束之前,乙不能向这张卡转账。 持久性(耐用性):事务完成后,事务对数据库的所有更新都将保存到数据库中,无法回滚 3.事务的隔离级别有哪些? 数据库事务有四种隔离级别,从低到高分别是未提交读取(Read uncommitted)、已提交读取(Read committed)、可重复读取(Repeatable read)、可序列化(Serializable)。此外,事务的并发操作中可能会出现脏读、不可重复读、幽灵读等情况。事务并发问题 脏读:事务 A 读取事务 B 更新的数据,然后事务 B 回滚操作,那么事务 A 读取的数据就是脏数据。 不可重复读取:事务 A 多次读取同一数据,事务 B 在事务 A 多次读取期间更新并提交数据,导致事务 A 多次读取同一数据时结果不一致。 幻影读取:系统管理员 A 将数据库中所有学生的具体分数改为 ABCDE 等级,但系统管理员 B 在此时插入了具体分数的记录,当系统管理员 A 更改结束后发现仍有一条记录未被更改,仿佛发生了幻觉,这称为幻影读取。 小结:不可重复读和幻读容易混淆,不可重复读侧重于修改,幻读侧重于增删。解决不可重复读问题只需锁定满足条件的行,解决幻读问题则需要锁定表 MySQL 事务隔离级别
-
linux 定时备份数据库 sql 文件(不备份表、视图、存储过程和已保存的查询语句)
-
在迭代器遍历过程中绕过数据修改异常的三种粗暴操作
-
像首席技术官一样思考:如何高效管理 30 人的研发团队?-管理越多越轻松。好的研发团队,应该是上拨下用,即下级对上级的向上管理;而不是反过来,总是向下管理,甚至是 CTO 做经理的事,经理做工程师的事,工程师最终会被当成实习生。如果是这样,就会越管越累,不仅团队无法成长,而且团队整天很忙还效率低下,问题一大堆。 有这样一个小故事:一位高级经理下班后帮忙倒垃圾,结果被老板训斥了一顿。这就好比首席技术官做了实习生自己该做的事。事情本身没有对错之分,只是从不同的角度有不同的理解。 古人云:"用人不疑,疑人不用"。在面对自己的研发团队时,应该相信他们能做好,授权一线开发人员充分发挥专业特长,不要限制他们的工作。但在相信他们的同时,也要进行二次确认,始终秉持 "我相信,但我要确认 "的原则和严谨的精神。因为每个人都会犯错和疏忽,通过发挥团队的智慧,团队犯错的机会就会大大减少。比如回归测试、代码审查、开发演示、变更审批等等。 如前所述,每个人都难免会犯错。但作为管理者,你所设计和商定的流程不能出错。管理者的每一个决定和沟通都应该经过深思熟虑。就像红绿灯的交通设计,某辆车不小心闯红灯可能会扣分,但红绿灯的设计一定要正确、人性化、统一。再比如,开发人员可能会因为疏忽大意写出 bug,但研发流程的设计和上线流程的发布不能有任何差错。因此,流程体系的设计,一方面要结合当前团队规模、业务特点和需要重点解决的问题来设计,另一方面也要在人员防错、效率提升、发挥团队集体智慧等维度进行综合考量。应该站在更高更抽象的角度去思考,不断思考一个倍受欢迎的园区应该如何设计,思考一个灵动、经典、永恒的建筑应该遵循怎样的模式,思考一个成功、优秀、卓越的研发团队应该需要怎样的流程和制度。 最后,反馈很重要。向上汇报很重要,向下反馈也很重要。能够保持顺畅的双向反馈和闭环管理,对研发团队的协作和沟通有着非常明显的积极作用。在向上汇报方面,要培养团队在正式汇报、会议汇报、私下沟通、书面总结、非正式场合等方面的沟通能力,提醒下属报喜也要报忧。凡事先记录,再跟进,最后反馈。反馈很重要,主动汇报更难得。 另一方面,同时也不要忽视向下反馈。好的爱,是双向的。团队也是如此,没有严格的上下级之分,只是分工和角色不同而已。作为管理者,不必总保持一种 "神秘感",让人 "捉摸不透 "才是牛。当团队做得好或有人做得好时,要记得在公开或私下场合给予肯定和赞许。业务有增长、业绩有提升时,别忘了给团队一些鼓励,或者安排一次下午茶或聚餐。在例会或正式会议上,也可以同步向大家传达一些重要信息和高层指示。"欲速则不达,欲远则同行"。 当向上汇报、向下反馈的沟通闭环形成后,同时结合前面研发过程的管理闭环,双管齐下,就能形成良性循环。如此反复,持之以恒,优秀卓越的研发团队,必将呈现。 能力、产出和效率 接下来,继续重复关于能力、产出和效率的话题。 站在不同的角色,以及一个企业经营、生存和发展所需要的基础上,我把研发生产力分为三个层次,分别是:一线员工关心的研发能力、管理层关心的软件产出和操作人员关心的企业生产效率。简单概括就是:既要把工作做好,又要能出成果,还要能帮企业赚钱。
-
openEuler郑州用户组成立!openEuler与hyperfusion携手共建河南地区用户生态 - 开幕致辞 超融合操作系统业务总经理、openEuler委员会成员蒋振华先生为本次活动致辞。 在本次活动的致辞中,他提到,作为openEuler社区早期的成员,超融合见证了openEuler从成立到在各行业商业落地,再到跨越生态拐点的过程,感谢openEuler提供了一个全产业链共同创新的平台,共同推动创新技术的商业落地。 同时,本次活动得到了郑州市郑东新区大数据管理局、郑州中原科技城投资服务局的大力支持。 郑东新区大数据管理局曹光远 在活动致辞中表示,openEuler的应用和*应用设施的深度优化,为郑东新区数字化转型提供了安全、可靠、高性能的技术基础;郑州中原科技城招商服务局王林表示,郑东新区欢迎所有openEuler生态相关企业扎根当地,围绕openEuler社区共同发展,形成合力。 openEuler社区及运维功能介绍 openEuler技术委员会委员胡峰 openEuler技术委员会委员胡峰先生在本次活动中介绍了openEuler社区目前发展的整体情况,并重点从技术层面介绍了openEuler的运维功能。 openEuler 晚会 胡峰先生介绍智能运维工具 A-Ops 和 openEuler gala、 阿波罗 Apollo、智能漏洞管理解决方案等新功能,以及涵盖各种运维场景的精品运维组件。在*交流环节,许多用户就目前使用的 openEuler 在*交流环节,许多用户就自己在使用openEuler过程中遇到的一些问题与胡峰先生进行了进一步的交流。 软硬结合,构建多样化算力操作系统 Hyperfusion 基于 openEuler 的基础上,结合自身软硬件技术积累,推出了富讯服务器操作系统 FusionOS FusionOS. FusionOS 首席架构师张海亮 分享了 FusionOS FusionOS首席架构师张海亮分享了FusionOS的软硬件协同优势、卓越的性能和可靠性,以及FusionOS在金融、运营商、*、互联网等行业的实践案例,引起了众多用户的兴趣,分享结束后,不少参会者就FusionOS的特点向讲师提问并进行了交流。
-
数据库(MySQL)基础]MySQL中的视图、存储过程和触发器 - 1. 视图
-
什么是可用性测试?有效性(Effectiveness)-- 用户完成特定任务和实现特定目标的正确性和完整性程度;效率(Efficiency)-- 用户完成任务的正确性和完整性程度与所用资源(如时间)之比;满意度(Satisfaction)-- 用户在使用产品时的主观满意度和接受程度。 2.如何获得可用性? 可以参考以下原则:Gould、Boies 和 Lewis(1991 年)为以用户为中心的设计定义了 4 个重要原则: 早期以用户为中心:设计者应在设计过程的早期就努力了解用户的需求。 综合设计:设计的所有方面都应同步发展,而不是按顺序进行。使产品的内部设计始终与用户界面的需求保持一致。 早期和持续测试:当今唯一可行的软件测试方法是经验主义方法,即如果实际用户认为设计可行,该设计就是可行的。通过在整个开发过程中引入可用性测试,用户就有机会在产品推出之前对设计提出反馈意见。 迭代设计:大问题往往掩盖了小问题的存在。设计人员和开发人员应在整个测试过程中对设计进行迭代。 3...什么是可用性测试? 可用性测试是根据可用性标准对图形用户界面进行的系统评估。 可用性测试是衡量用户与系统(网站、软件应用程序、移动技术或任何用户操作设备)交互时的体验质量。4.如何进行可用性测试? l 实验室实验
-
PS 为图层制作斜面效果的操作过程