八、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' //存储过程 ...
随机推荐
- warning C4819: 该文件包含不能在当前代码页(936)中表示的字符。请将该文件保存为 Unicode 格式以防止数据丢失
bug来源: 一直在看sift然后就手贱的给 opencv源码做注释,如果在vs里面打开会一直相安无事,但是问题出在我用了notepad++. 这样就报了标题的错误. 因为notepad++会以uni ...
- Linux 命令 - netstat: 检查网络设置及相关统计数据
netstat 程序可以用于查看不同的网络设置及数据.通过使用其丰富的参数选项,我们可以查看网络启动过程的许多特性. 命令格式 netstat [options] 命令参数 -r, --route 显 ...
- HDOJ2011多项式求和
多项式求和 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submi ...
- Objective-C中一个方法如何传递多个参数的理解
原来如此 Objective-C语法中多参数传递方法经常是初学者最容易犯困的地方.我自己也是刚刚悟出来与大家分享. 分析 由于我们已有的语言经验告诉我们定义方法都是: 一个类型匹配一个参数(动态语言甚 ...
- php学习-快速开发框架thinkphp-day1
以下操作针对windows系统. 1.下载thinkphp3.23-all并解压 官方网站: http://www.thinkphp.cn/down.html 2.开发工具使用phpstorm htt ...
- Android之帧动画2
创建自定义对话框: // 对话框构建器 Builder builder = new AlertDialog.Builder(this); // 创建出一个空的对话框 final AlertDialog ...
- Cocos2d-x开发实例介绍帧动画使用
下面我们通过一个实例介绍一下帧动画的使用,这个实例如下图所示,点击Go按钮开始播放动画,这时候播放按钮标题变为Stop,点击Stop按钮可以停止播放动画. 下面我们再看看具体的程序代码,首先看一下看H ...
- LINQ(隐式表达式、lambda 表达式)
.NET 中一项突破性的创新是 LINQ(Language Integrated Query,语言集成查询),这组语言扩展让你能够不必离开舒适的 C# 语言执行查询. LINQ 定义了用于构建查询表达 ...
- C++ VARIANT 学习小记录
一:为什么会有这个? 目前,计算机语言有很多(大哥,为什么不能就那么一样呢?),如C++.Java,此外还有JavaScript.VBScript等脚本语言,它们自立门派,各自维护自己的数据类型. C ...
- 在Centos6.5安装MySQL
在阐述安装过程之前一定要再写一句,Centos7上安装MySQL是默认安装的MariaDB,因为在Centos7中用MariaDB代替了mysql数据库. linux安装软件很简单,有的时候只有一句话 ...