八、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' //存储过程 ...
随机推荐
- Mysql 复习
1.my.ini :mysql 配置文件 [client]#password = your_passwordport = 3306socket = /tmp/mysq ...
- 给jdk写注释系列之jdk1.6容器(10)-Stack&Vector源码解析
前面我们已经接触过几种数据结构了,有数组.链表.Hash表.红黑树(二叉查询树),今天再来看另外一种数据结构:栈. 什么是栈呢,我就不找它具体的定义了,直接举个例子,栈就相当于一个很窄的木桶 ...
- DHCP服务详解
DHCP概念和原理 dhcp服务作用 为大量客户机自动分配地址,提供集中管理 减轻管理和维护成本,提高网络配置效率 可分配的地址信息主要包括: 网卡的IP地址.子网掩码 对应的网络地址 默认网关地址 ...
- MyBatis(3.2.3) - Handling enumeration types
MyBatis supports persisting enum type properties out of the box. Assume that the STUDENTS table has ...
- iBeacon
iBeacon[1] 是苹果公司2013年9月发布的移动设备用OS(iOS7)上配备的新功能.其工作方式是,配备有 低功耗蓝牙(BLE)通信功能的设备使用BLE技术向周围发送自己特有的ID,接收到该I ...
- jquery---helloworld
style.css
- Sql server 大全
一.基础 .说明:删除数据库drop database dbname3.说明:备份sql server--- 创建 备份数据的 deviceUSE masterEXEC sp_addumpdevice ...
- Java之绘制艺术图案
前面已经介绍过绘制方法.这里不再赘述. package com.caiduping; import java.awt.Color; import java.awt.Graphics; import j ...
- 打造属于自己的安卓Metro界面
前言: 各位小伙伴,又到了每周更新文章了时候了,本来是周日能发出来呢,这不是赶上清明节吗,女王大人发话了,清明节前两天半陪她玩,只留给我周一下午半天时间写博客,哪里有女王哪里就有压迫呀有木有!好了闲话 ...
- Java开源 开源工作流
OpenEbXML 点击次数7801 Werkflow 点击次数11181 OSWorkflow 点击次数14988 wfmOpen 点击次数7997 OFBiz 点击次数1234 ...