八、mysql视图、存储过程、函数以及时间调度器
1.create or replace view emp_view as select * from t4 ;给t4表创建一个名为emp_view的视图 2.drop view emp_view 删除视图 ======================================= 1.创建一个存储过程(查询所有数据)
create procedure p1 ()
READS SQL DATA
BEGIN
select * from t4;
END 2.创建一个存储过程(查询传参数据)
create procedure p2(IN tid INT)
READS SQL DATA
BEGIN
select * from t4 where id = tid;
END 3.创建一个存储过程(查询传参数据并返回name)
create procedure p3(IN tid INT,OUT tname CHAR(255))
READS SQL DATA
BEGIN
select name from t4 where id = tid into tname;
END ==========================================
1.创建一个存储函数(函数必须有返回值)
create function p4(IN tid INT)
RETURNS CHAR(255)
DETERMINISTIC
READS SQL DATA
BEGIN
DECLARE t_name CHAR(255);
SELECT tname from t4 where id = tid into t_name;
RETURN t_name;
END ===========================================
1.定义错误条件和处理
情景1:比如过程中要插入的数据唯一键值已存在
create procedure p5 ()
BEGIN
DECLARE CONTINUE HANDLER FOR SQLSTATE '' set @x2 = 1; //23000在mysql中代表建已存在或重复的错误代码
set @x = 1;
insert into ...... //假设这条不重复
set @x = 2;
insert into ...... //假设这条不重复
set @x = 3;
insert into ..... //重复
END 调用:
call p5();select @x,@x2;
将输出:3,1 原因:前面2条都顺利执行,@x = 3,最后一条重复,也就是将@x2设置成了1; =============================================
1.光标概念(实际上就是fetch结果集用的)
create procedure p6()
READS SQL DATA //表示过程只包含读不包含写
BEGIN
DECLARE tid int;//定义id
DECLARE tname char;//定义name
DECLARE tcur cursor for select id,name from t4;//定义光标
DECLARE exit handler for not found tcur;//如果光标为空则退出,不允许继续执行
set @error = '';//设置返回调用error
open tcur;
repeat
fetch tcur into tid,tname;
if tid = 1 then
set @error = '我是1,但是我报错了';
else
set @error = '我不是1啊,真的啊!';
end if;
until 0 end repeat;
close tcur;//关闭
END; ===============================================
1.流程控制
if:
if 1=1 then
我是1;
else
我不是1;
end if case:
case
when 1=1 then
我是1;
else
我不是1;
end case loop:
emp: LOOP
#...code.....
END LOOP emp; leave emp;//表示从标注的流程中退出(emp表示上面loop的标注) 相当于php中break,只不过leave要指定需要被跳出的结构体 iterate emp;//表示此次循环跳过余下的代码块 相当于php中的continue repeat:
repeat //循环开始相当于php的do...while...(因为他是在循环结束的时候做判断,因此此循环体至少会被执行一次)
#....code.... //相关内容
until 1=2 end repeat //如果条件为假则退出循环 while://跟php中的while一个概念,只是语法区别
while 1=1 do //很明显,这是个死循环
#...code.....
end while; ================================================
1.时间触发器(时间调度器)
1.默认时间触发器是关闭状态
set GLOBAL event_scheduler = 1 开启
2.show variables like 'scheduler' 查看时间调度器开启/关闭状态
3.show events;//查看所有调度器
4.alter event emp disable; //禁用名为emp的调度器
5.drop event emp; //删除名为emp的调度器
6.创建一个调度器
create event emp //调度器名次
on schedule every 5 second //时间5秒
do //开始
insert into haha values (NULL); //执行体 ================================================= PS::2014-07-08 继续学习ing.....
八、mysql视图、存储过程、函数以及时间调度器的更多相关文章
- MySQL:日期函数、时间函数总结(MySQL 5.X)
http://www.cnblogs.com/she27/archive/2009/01/16/1377089.html 原文:http://www.51sdj.com/phpcms/picture/ ...
- 【转】MySQL:日期函数、时间函数总结(MySQL 5.X)
转自:http://www.cnblogs.com/she27/articles/1377089.html 一.MySQL 获得当前日期时间 函数1.1 获得当前日期+时间(date + time)函 ...
- MySQL存储过程中的3种循环,存储过程的基本语法,ORACLE与MYSQL的存储过程/函数的使用区别,退出存储过程方法
在MySQL存储过程的语句中有三个标准的循环方式:WHILE循环,LOOP循环以及REPEAT循环.还有一种非标准的循环方式:GOTO,不过这种循环方式最好别用,很容易引起程序的混乱,在这里就不错具体 ...
- MySQL:日期函数、时间函数总结
MySQL 获得当前日期时间 函数 获得当前日期+时间(date + time)函数:now() mysql> select now(); +---------------------+ | n ...
- Mysql日期转换函数、时间转换函数
Mysql日期转换函数.时间转换函数 一.MySQL 获得当前日期时间 函数 1,获得当前日期+时间(date + time)函数:now(): select now(); 结果: :: 2,获得当前 ...
- mysql使用存储过程&函数实现批量插入
写这边文章的目的,是想结合mysql 存储过程+函数完成一个批量删除的功能吧...正好也好加深下对procedure和function的熟练操作吧...废话不多说,我就直接上表结构啦哈,如下: cre ...
- MySQL创建存储过程/函数需要的权限
alter routine---修改与删除存储过程/函数 create routine--创建存储过程/函数 execute--调用存储过程/函数 下面有一篇介绍MySQL所有权限的博文 http:/ ...
- MySQL视图,函数,触发器,存储过程
1. 视图 视图是一个虚拟表,它的本质是根据SQL语句获取动态的数据集,并为其命名,用户使用时只需使用[名称]即可获取结果集,可以将该结果集当做表来使用. 使用视图我们可以把查询过程中的临时表摘出来, ...
- mysql查看存储过程函数
查询数据库中的存储过程和函数 select `name` from mysql.proc where db = 'xx' and `type` = 'PROCEDURE' //存储过程 ...
随机推荐
- POWER DESIGN
一.概念数据模型概述数据模型是现实世界中数据特征的抽象.数据模型应该满足三个方面的要求:1)能够比较真实地模拟现实世界2)容易为人所理解3)便于计算机实现 概念数据模型也称信息模型,它以实体-联系(E ...
- c# 友元程序集
在团队开发中,如果一个程序集中要调用另外一个程序集,但是要被调用的那个程序集又不想用public来公开自己的类, 那么怎么办,就是用最后一种internal来用来做类的可见性了. 下面来看一个简单例子 ...
- 使用git ftp发布我个人的hexo博客内容
自己虚拟主机中的博客是由hexo3 + next主题,因为我想将 hexo 编译生成的文件可以通过ftp命令发布到ftp服务器上面. 发布使用的工具是git-ftp: 按照Use Jenkins an ...
- C#入门教程(一)–.Net平台技术介绍、C#语言及开发工具介绍-打造C#学习教程
一.什么是.Net平台? .Net平台是微软搭建的技术平台,技术人员在此平台上进行应用的搭建与开发.它提供了运行所必须的环境.NET Framework类库以及CLR(公共语言运行时).好比我们人类的 ...
- 初学JSP+Servlet常见的错误
web编程中常见的错误: 一.404(要访问的资源没有找到) 1.web程序有没有部署(将项目到tomcat中) 2.url有没有写错(包括大小写,包括项目有没有重命名) 3.有没有将jsp/html ...
- 【转载】常用Maven插件介绍
http://www.cnblogs.com/crazy-fox/archive/2012/02/09/2343722.html 我们都知道Maven本质上是一个插件框架,它的核心并不执行任何具体的构 ...
- [盈利指导] [原创]五蕴皆空:App推广干货,排名数据分析优化效果
App盈利交流论坛版主第一帖2015年3月份,在百度上了一款赛车类游戏(不说什么名字了怕被打包),后台起名叫002,刚开始上的时候一天只有几元钱,但是游戏还是倾注了不少心血的,觉得不甘心, ...
- Android应用源码基于安卓的校园二手交易系统客户端+服务端+数据库
该源码是校园二手交易系统应用带服务端,也是一个基于安卓和javaweb的校园二手交易系统,包括整套安卓客户端.javaweb服务端.mysql数据库,可以进行基本的列表显示帖子.显示帖子详情.用户注册 ...
- C#中的二进制序列化和Json序列化
序列化就是把一个对象变成流的形式,方便传输和还原.小弟不才,总结下对二进制序列化和Json序列化的使用: 1.首先,二进制序列化(BinaryFormatter)要求要序列化的类必须是可序列化的(即在 ...
- 学习Learn Python The Hard Way 前言中的一段话,可与君共勉
在你通过这本书学习编程时,我正在学习弹吉他.我每天至少训练 2 小时,至少花一个小时练习音阶.和声.和琶音,剩下的时间用来学习音乐理论和歌曲演奏以及训练听力等.有时我一天会花 8 个小时来练习,因为我 ...