八、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' //存储过程 ...
随机推荐
- python(3)-动态参数实现字符串格式化
s1 = "{0} ===> {1}" s = s1.format('lilei', 'boy') print(s) l = ['lilei', 'boy'] s = s1. ...
- 进程间通信之管道(pipe、fifo)
我们先来说说进程间通信(IPC)的一般目的,大概有数据传输.共享数据.通知事件.资源共享和进程控制等.但是我们知道,对于每一个进程来说这个进程看到属于它的一块内存资源,这块资源是它所独占的,所以进程之 ...
- yii2在ubuntu下执行定时任务
一.编辑yii console/controllers TestController.php 二./usr/ 包括与系统用户直接有关的文件和目录创建sh_scripts目录,/usr/sh_scrip ...
- [改善Java代码]频繁插入和删除时使用LinkedList
一.分析 前面有文章分析了列表的表里方式,也就是“读”的操作.本文将介绍表的“写”操作:即插入.删除.修改动作. 二.场景 1.插入元素 列表中我们使用最多的是ArrayList,下面看看他的插入(a ...
- 关于location.href几种用法的区别
常见的几种开发形式: self.location.href; window.location.href; this.location.href; location.href; parent.locat ...
- button轮番点击,只点击一次,鼠标hover
<!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml"><head><meta ...
- C# 截图类
注意修改命名空间using System.Drawing; using System.Windows.Forms; namespace WindowsFormsApplication1 { ...
- 关于java.lang.NullPointerException: Module 'null' not found.的问题
在用eclipse做struts1项目时,配置都ok了.可是一运行就报java.lang.NullPointerException: Module 'null' not found.错. 代码如下: ...
- Spring(3.2.3) - Beans(8): 基于 Annotation 的配置
除了基于 XML 的配置外,Spring 也支持基于 Annotation 的配置.Spring 提供以下介个 Annotation 来标注 Spring Bean: @Component:标注一个普 ...
- Tomcat - JNDI 配置
1. Create Your JavaBean Class Create the JavaBean class which will be instantiated each time that th ...