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

网站的电子地图怎么做宁波百度seo排名优化

网站的电子地图怎么做,宁波百度seo排名优化,电子商务网站搜索引擎设计,慕枫宁波网站建设目录 1. 游标1.1 声明游标1.2 打开游标1.3 读取游标1.4 关闭游标1.5 游标示例 2. 触发器2.1 创建触发器2.2 修改触发器2.3 删除触发器2.4 触发器类型2.5 触发器示例 参考书籍 1. 游标 游标一般和存储过程一起配合使用。 1.1 声明游标 要使用游标,需要用到 DECLAR…

目录

  • 1. 游标
    • 1.1 声明游标
    • 1.2 打开游标
    • 1.3 读取游标
    • 1.4 关闭游标
    • 1.5 游标示例
  • 2. 触发器
    • 2.1 创建触发器
    • 2.2 修改触发器
    • 2.3 删除触发器
    • 2.4 触发器类型
    • 2.5 触发器示例
  • 参考书籍

1. 游标

游标一般和存储过程一起配合使用。

1.1 声明游标

要使用游标,需要用到 DECLARE CURSOR 语句:

DECLARE 游标名 CURSOR FOR SELECT语句

:一个存储过程可以声明多个游标,但是一个块中的每一个游标必须具有唯一的名字。

1.2 打开游标

要使用游标,需要用到 OPEN 语句:

OPEN 游标名;

1.3 读取游标

要使用游标,需要用到 FETCH...INTO 语句:

FETCH 游标名 INTO 变量名, ...

1.4 关闭游标

要使用游标,需要用到 CLOSE 语句:

CLOSE 游标名;

:游标使用完以后要 及时关闭

1.5 游标示例

【例】在数据库 score 中查询某个学院某门课程的成绩(方法一)

drop PROCEDURE if EXISTS p1;
delimiter $
create PROCEDURE p1(in did char(10), in lid char(10))
begindeclare stu_id char(15);declare lname char(20);declare stu_score int;declare score_count int;		# 统计记录数declare i int default 1;# 设置游标declare c_score CURSOR forselect stu.id, lesson.lessonName, score.scorefrom stu join score on stu.id = score.stuIdjoin lesson on score.LessonId = lesson.lessonidjoin department on stu.departmentId = department.idwhere stu.departmentId = did and score.LessonId = lid;select count(*) into score_countfrom (select stu.id, lesson.lessonName, score.scorefrom stu join score on stu.id = score.stuIdjoin lesson on score.LessonId = lesson.lessonidjoin department on stu.departmentId = department.idwhere stu.departmentId = did and score.LessonId = lid)a;open c_score;    # 打开游标while i <= score_count doFETCH c_score into stu_id, lname, stu_score;		# 读取游标select stu_id, lname, stu_score;		# 使用游标set i = i + 1;end while;close c_score;		# 关闭游标end $
delimiter ;# 一般在命令列界面运行可以明显看出所要查看的数据
call p1('101', '101');

如果是在可视化界面运行 call p1('101', '101');,效果如下(不方便查看,数据是一条条输出的):

在这里插入图片描述

在命令列界面运行 call p1('101', '101');,方便查看:

在这里插入图片描述

我们也尝试不用存储过程直接输出结果,发现结果是一样的(除了输出顺序不同):

select stu.id, lesson.lessonName, score.scorefrom stu join score on stu.id = score.stuIdjoin lesson on score.LessonId = lesson.lessonidjoin department on stu.departmentId = department.idwhere stu.departmentId = '101' and score.LessonId = '101';

在这里插入图片描述

2. 触发器

2.1 创建触发器

用代码创建:

CREATE TRIGGER 触发器名 触发时刻 触发事件ON 表名 FOR EACH ROW 触发器动作

不过为了方便,我们可以直接使用可视化界面创建触发器。

2.2 修改触发器

建议直接在 Navicat 上进行创建、修改、删除触发器,在设计表中点击触发器即可。

在这里插入图片描述

2.3 删除触发器

前面说了可以直接使用 Navicat 删除触发器。

下面也给出相关代码:

DROP TRIGGER [数据库名.]触发器名

2.4 触发器类型

触发器只有 3 种类型:插入更新删除。每种类型又有 2 种情况:BEFOREAFTER

每个类型每种情况的触发器在一张表只能设置 1,即一张表最多只有 6 个触发器。

对于 事件、全局锁、表锁、行锁和死锁 的内容在此不过多赘述,大家要是感兴趣可以自行了解~

2.5 触发器示例

使用 bank 数据库,创建表 info,利用触发器完成以下内容。下面会给出如何用 SQL 语句创建触发器并完成相应功能。

info 的内容如下:

在这里插入图片描述

  1. 插入存取款记录(触发器 tri_insertinfo)——需要判断用户账号是否存在。

    drop trigger if EXISTS tri_insertinfo;
    delimiter $
    create TRIGGER tri_insertinfo before insert on info for each row
    begindeclare a int;select count(*) into afrom accountwhere account.id = new.accountid;if a = 0 then SIGNAL SQLSTATE '12345' set message_text = '账号不存在';end if;if new.type = 'save' thenupdate accountset ck = ck + new.balancewhere account.id = new.accountid;elseupdate accountset ck = ck - new.balancewhere account.id = new.accountid;end if;end$
    delimiter ;
    

    查看当前所有用户存款:

    select * from account;
    

    在这里插入图片描述

    张三存入 500 元,并查看当前全部用户存款:

    insert into info values(null, '001', 'save', 500);
    select * from account;
    

    在这里插入图片描述

    李四取出 500 元:

    insert into info values(null, '002', 'load', 500);
    select * from account;
    

    在这里插入图片描述

    给用户编号为 005 (不存在用户)存入 500 元:

    insert into info values(null, '005', 'save', 500);		# 会显示账号不存在
    

    在这里插入图片描述

  2. 创建触发器 tri_deleteinfo 撤销存取款记录(info 中的记录)。

    drop trigger if EXISTS tri_deleteinfo;
    delimiter $
    create TRIGGER tri_deleteinfo after delete on info for each row
    beginif old.type = 'save' thenupdate accountset ck = ck - old.balancewhere account.id = old.accountid;elseupdate accountset ck = ck + old.balancewhere account.id = old.accountid;end if;end$
    delimiter ;
    

    撤销编号为 16 的取款操作:

    delete from info where id = 16;		# 撤销id为16的操作
    select * from account;
    

    在这里插入图片描述
    可见李四的账户从 5550 恢复到上次的 6050

    清除所有的存取款操作:

    delete from info;		# 撤销所有存取款操作,金额恢复
    select * from account;
    

    在这里插入图片描述
    可见张三的账户金额出现了负数,这其实是异常结果,所以大家可以自行在源代码里面新增报告异常的语句。

    按照道理来说不会出现这种情况,可能是我之前操作数据时改变了记录~

  3. 创建触发器 tri_updateinfo,用于修改用户存取款金额数。

    drop trigger if EXISTS tri_updateinfo;
    delimiter $
    create TRIGGER tri_updateinfo after update on info for each row
    beginif old.type = 'save' thenupdate accountset ck = ck - old.balance + new.balancewhere account.id = old.accountid;elseupdate accountset ck = ck + old.balance - new.balancewhere account.id = old.accountid;end if;end$
    delimiter ;
    

    其实这个操作基本上用不上,毕竟用户存、取多少就是多少,而且这个操作可以用前面两个触发器实现,因此这里不展示修改操作了~

参考书籍

《MySQL实用教程(第4版)》

上一篇文章:【数据库——MySQL】(13)过程式对象程序设计——存储函数、错误处理以及事务管理

http://www.yidumall.com/news/19578.html

相关文章:

  • 门户网站 开发注意新闻稿件代发平台
  • 东莞寮步二手车交易市场临沂seo排名外包
  • 做网站的设计文档怎么做百度安装应用
  • 酷炫网站设计风格seo资讯
  • 网站如何续费本地推荐本地推荐
  • wordpress 网页很慢广州seo效果
  • 外贸网站模板 外贸网站制作武汉seo 网络推广
  • 企业网站颜色网络舆情监测与研判
  • 电商网站的费用怎么做帐23岁老牌网站
  • 国外网站建设公司百度霸屏推广
  • 电力通信网网络架构免费优化网站排名
  • 本土建站工作室百度爱采购竞价
  • 网站如何建设与优化百度热搜榜排名今日头条
  • 做网站还赚钱么百度服务中心官网
  • 网站建设 重庆seo职位要求
  • 手机微信官方网站首页百度seo排名曝光行者seo
  • 网站建设需要会什么软件搜索引擎优化怎么做的
  • 网站开发工作量百度关键字搜索量查询
  • 网站做海外的防护泉州搜索推广
  • 深圳外贸建站模版小说关键词生成器
  • 网站开发项目合同关键词林俊杰免费听
  • 武汉网站开发建设网络营销方法有哪些举例
  • 网站改版打造全新网站营销网站建设多少钱
  • 西安电商网站制作怎么查询最新网站
  • 免费做网站公司推荐怎么给自己的公司建立网站
  • 广东网站备案审核时间百度排行榜风云榜
  • 做系统网站好谷歌广告平台
  • html5网站建设微信运营公司织梦模板wordpress网站建设
  • 网站开发怎么报价seo网络营销推广排名
  • 怎样用js做网站轮播图网站快速刷排名工具