当前位置: 首页 > news >正文

茶楼网站源码做网站花了三万块

茶楼网站源码,做网站花了三万块,公司做网站有什么用,长春网站优化指导目录 一.游标 格式 操作 演示 二.异常处理—handler句柄 格式 演示 三.存储函数 格式 参数说明 演示 四.存储过程总结 一.游标 游标(cursor)是用来存储查询结果集的数据类型,在存储过程和函数中可以使用游标对结果集进行循环的处理。游标的使用包括游标的声明、OPEN、…

目录

一.游标

格式

操作

 演示

二.异常处理—handler句柄

格式

 演示

 三.存储函数

格式

 参数说明

演示

四.存储过程总结


 

一.游标

游标(cursor)是用来存储查询结果集的数据类型,在存储过程和函数中可以使用游标对结果集进行循环的处理。游标的使用包括游标的声明、OPEN、FETCH和 CLOSE.

格式

 

操作

 演示

use test_procedure ;
-- 需求:输入一个部门名,查询该部门员工的编号、名字、薪资,将查询的结果集添加游标
delimiter $$
create procedure proc21(in in_name varchar(50))
begin-- 定义局部变量declare var_empno int;declare var_ename varchar(50);declare var_sal decimal(7,2);-- 声明游标declare my_cursor cursor forselect empno ,ename ,sal  from emp e,dept d where d.dname =in_name ;-- 打开游标open my_cursor;-- 通过游标获得值fetch my_cursor into var_empno,var_ename,var_sal;select var_empno,var_ename,var_sal;-- 关闭游标close my_cursor;
end $$
delimiter ;call proc21('销售部');

运行输出的结果是

但是

 我们发现符合要求的有多个值,这是因为游标是一条条往下执行的所以我们可以用一个循环

use test_procedure ;
-- 需求:输入一个部门名,查询该部门员工的编号、名字、薪资,将查询的结果集添加游标
delimiter $$
create procedure proc21(in in_name varchar(50))
begin-- 定义局部变量declare var_empno int;declare var_ename varchar(50);declare var_sal decimal(7,2);-- 声明游标declare my_cursor cursor forselect empno ,ename ,sal  from emp e,dept d where d.dname =in_name ;-- 打开游标open my_cursor;-- 通过游标获得值label:loopfetch my_cursor into var_empno,var_ename,var_sal;select var_empno,var_ename,var_sal;end loop label;-- 关闭游标close my_cursor;
end $$
delimiter ;call proc21('销售部');

 结果会报错

No data - zero rows fetched, selected, or processed 这句话意思是没有数据 零行 读取 选择或处理,就是说循环到最后没值了,所以我们需要找到一个条件并及时退出循环,这就需要异常处理—handler句柄。

二.异常处理—handler句柄

格式

 注意

在语法中,变量声明、游标声明、handler声明是必须按照先后顺序书写的,否则创建存储过程出错。

--定义句柄:定义异常的处理方式

1:异常处理完之后程序该怎么执行
        continue :继续执行剩余代码

        exit :直接终止程序
        undo:不支持
2:触发条件

条件码:1329

条件名:
        SQLWARNING

        NOT FOUND

        SQLEXCEPTION

 演示

-- 用条件名
use test_procedure ;
-- 需求:输入一个部门名,查询该部门员工的编号、名字、薪资,将查询的结果集添加游标
delimiter $$
create procedure proc22(in in_name varchar(50))
begin-- 定义局部变量declare var_empno int;declare var_ename varchar(50);declare var_sal decimal(7,2);-- 定义标记值declare flag int default 1;-- 声明游标declare my_cursor cursor forselect empno ,ename ,sal  from emp e,dept d where d.dname =in_name ;-- 定义句柄,当数据未发现时将标记位设置为0declare continue handler for  not found set flag=0;-- 打开游标open my_cursor;-- 通过游标获得值label:loopfetch my_cursor into var_empno,var_ename,var_sal;if flag=1 thenselect var_empno,var_ename,var_sal;elseleave label;end if;end loop label;-- 关闭游标close my_cursor;
end $$
delimiter ;call proc22('销售部');-- 用条件码
use test_procedure ;
-- 需求:输入一个部门名,查询该部门员工的编号、名字、薪资,将查询的结果集添加游标
delimiter $$
create procedure proc23(in in_name varchar(50))
begin-- 定义局部变量declare var_empno int;declare var_ename varchar(50);declare var_sal decimal(7,2);-- 定义标记值declare flag int default 1;-- 声明游标declare my_cursor cursor forselect empno ,ename ,sal  from emp e,dept d where d.dname =in_name ;-- 定义句柄,当数据未发现时将标记位设置为0declare continue handler for  1329 set flag=0;-- 打开游标open my_cursor;-- 通过游标获得值label:loopfetch my_cursor into var_empno,var_ename,var_sal;if flag=1 thenselect var_empno,var_ename,var_sal;elseleave label;end if;end loop label;-- 关闭游标close my_cursor;
end $$
delimiter ;call proc23('销售部');

两个的运行结果是一样的

 三.存储函数

格式

在MySQL中,创建存储函数使用create function关键字,其基本形式如下:

 参数说明

(1) func_name :存储函数的名称。
(2) param_name type:可选项,指定存储函数的参数。type参数用于指定存储函数的参数类型,该类型可以是MySQL数据库中所有支持的类型。
(3)returns type:指定返回值的类型。
(4)characteristic:可选项,指定存储函数的特性。
(5)routine_body: SQL代码内容。

演示

drop function if exists myfunc1_emp;
delimiter $$
create function myfunc1_emp() returns int
begindeclare cnt int default 0;select count(*) into cnt from emp;return cnt;
end $$
delimiter ;

运行结果可以会报错,像这样

 意思是说“此函数在其声明中没有确定性、无 SQL 或读取 SQL 数据,并且启用了二进制日志记录(您*可能*希望使用不太安全的 log_bin_trust_function_creators 变量)”

所以我们设置允许创建函数权限信任即可

-- 允许创建函数权限信任
set global log_bin_trust_function_creators=true ;

-- 允许创建函数权限信任
set global log_bin_trust_function_creators=true ;drop function if exists myfunc1_emp;
delimiter $$
create function myfunc1_emp() returns int
begindeclare cnt int default 0;select count(*) into cnt from emp;return cnt;
end $$
delimiter ;-- 调用存储函数
select myfunc1_emp();

 这样就可以了

四.存储过程总结

 

 

 

 

 

 

 

 

http://www.yayakq.cn/news/682492/

相关文章:

  • 温州网站建设价格会网站建设好吗
  • 建设网站多少费用图书馆网站建设所需资料
  • excel做公司的小网站网页编辑软件朱
  • 莆田建站服务搜索引擎优化什么意思
  • 用wampserver搭建网站asp.net网站本机访问慢
  • 网站代码seo优化中国设计最好的网站
  • 莆田网站建设咨询一个新手建设网站怎么简单
  • 网站图片计时器怎么做石家庄seo培训
  • 免费个人网站 上传app store下载安卓
  • 网站开发的认知网络广告学心得体会
  • 专业的丹阳网站建设wordpress标签美化代码
  • 有域名有网站怎么解决办法广州火车站
  • 万网的网站代码怎么看建筑劳务公司名字起名大全
  • 网站名字怎么取最好网站自己做流量
  • 网站开发可选择方案有哪些wordpress设置付费阅读
  • 承德网站建设公司从化营销型网站建设
  • 百度网站搜索排名鹤山区网站建设
  • 优惠券网站做淘客违规吗wordpress gd
  • 做外贸去哪些网站找老外手机优化大师官方版
  • 做网站找我们网站百度地图导航代码生成
  • 研发网站建设报价网站上的代码网页怎么做的
  • 中小网站 架构网站开发的初级技术员
  • 襄樊市网站建设公司网站构建技术
  • 昆明网站建设公司猎狐科技怎么样wordpress 密码爆破
  • 企业网站前端模板网络宣传策划方案
  • 佛山网站seo优化厦门跨境建站平台
  • 大型网站开发用的技术做网站需要哪些资质
  • 厦门学校网站建设南昌地宝网二手房出售信息
  • 做网站的分辨率多少沈阳设计培训网站建设
  • 咸阳网站开发哪家好进贤城乡规划建设局网站