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视图、存储过程、函数以及时间调度器的更多相关文章

  1. MySQL:日期函数、时间函数总结(MySQL 5.X)

    http://www.cnblogs.com/she27/archive/2009/01/16/1377089.html 原文:http://www.51sdj.com/phpcms/picture/ ...

  2. 【转】MySQL:日期函数、时间函数总结(MySQL 5.X)

    转自:http://www.cnblogs.com/she27/articles/1377089.html 一.MySQL 获得当前日期时间 函数1.1 获得当前日期+时间(date + time)函 ...

  3. MySQL存储过程中的3种循环,存储过程的基本语法,ORACLE与MYSQL的存储过程/函数的使用区别,退出存储过程方法

    在MySQL存储过程的语句中有三个标准的循环方式:WHILE循环,LOOP循环以及REPEAT循环.还有一种非标准的循环方式:GOTO,不过这种循环方式最好别用,很容易引起程序的混乱,在这里就不错具体 ...

  4. MySQL:日期函数、时间函数总结

    MySQL 获得当前日期时间 函数 获得当前日期+时间(date + time)函数:now() mysql> select now(); +---------------------+ | n ...

  5. Mysql日期转换函数、时间转换函数

    Mysql日期转换函数.时间转换函数 一.MySQL 获得当前日期时间 函数 1,获得当前日期+时间(date + time)函数:now(): select now(); 结果: :: 2,获得当前 ...

  6. mysql使用存储过程&函数实现批量插入

    写这边文章的目的,是想结合mysql 存储过程+函数完成一个批量删除的功能吧...正好也好加深下对procedure和function的熟练操作吧...废话不多说,我就直接上表结构啦哈,如下: cre ...

  7. MySQL创建存储过程/函数需要的权限

    alter routine---修改与删除存储过程/函数 create routine--创建存储过程/函数 execute--调用存储过程/函数 下面有一篇介绍MySQL所有权限的博文 http:/ ...

  8. MySQL视图,函数,触发器,存储过程

    1. 视图 视图是一个虚拟表,它的本质是根据SQL语句获取动态的数据集,并为其命名,用户使用时只需使用[名称]即可获取结果集,可以将该结果集当做表来使用. 使用视图我们可以把查询过程中的临时表摘出来, ...

  9. mysql查看存储过程函数

    查询数据库中的存储过程和函数 select `name` from mysql.proc where db = 'xx' and `type` = 'PROCEDURE'   //存储过程       ...

随机推荐

  1. iOS之原生地图与高德地图

    原生地图 1.什么是LBS LBS: 基于位置的服务 Location Based Service 实际应用:大众点评,陌陌,微信,美团等需要用到地图或定位的App 2.定位方式 1.GPS定位 2. ...

  2. 为Google Reader守夜。。。

    Google的阅读器快要关闭了... 立刻截图留恋呢,以后就没机会了. 唉,真是令人惋惜. 虽然我接触Google Reader还不到一年,但是我已经习惯当连上WiFi时马上更新一下手机上的gRead ...

  3. [辛酸历程]在Mac中使用Python获取屏幕截图

    一.起因 最近想做个小外挂玩玩,技术倒是不难,就是通过图片匹配加上一些判断方法来刷分.但是在最不起眼(却最容易出问题)的准备阶段卡住了. 为什么卡住了呢,简单说,因为我需要获取截屏的数据,所以就要找一 ...

  4. The Story of self Parameter in Python, Demystified

      转自:http://www.programiz.com/article/python-self-why If you have been programming in Python (in obj ...

  5. JavaScript中常用函数(入门级)(持续更新)

    本文中枫竹梦介绍一些JavaScript中入门级的常用函数,对于已经过了入门的童鞋可选择略过,都是一些非常实用的函数.如果发现什么问题,欢迎讨论. 问题列表 Q1: 设计一个函数repeatIt(st ...

  6. CentOS(七)--Linux文件类型及目录配置

    这篇随笔将会对Linux系统的文件类型以及Linux的目录结构进行详细补充(linux中目录管理和权限非常重要,特别是在linux安装数据库类软件). 一.Linux更改文件权限的两种方式 在之前的一 ...

  7. 命名管道FIFO

    首先我得检讨一下自己,这几天有些颓呀,打不起精神,板子出了点问题,果真自学还是很困难呀,硬件方面难解决呀,理想与现实还是很有差距的,伤透了,凌乱了. 一直在理解进程间通信的问题.发现上次忽略了一个问题 ...

  8. 只能在执行 Render() 的过程中调用 RegisterForEventValidation(RegisterForEventValidation can only be called during Render();

    只能在执行 Render() 的过程中调用 RegisterForEventValidation(RegisterForEventValidation can only be called durin ...

  9. web前端常用小函数汇总

    //去掉html标签 function delHtmlTag(str) { var title = str.replace(/<[^>]+>/g, "");// ...

  10. Ajax具体使用

    Ajax在注册页面经常使用,当注册用户是用户名必须唯一时,要使用ajax获取表单中你输入的内容, 然后将这个数据利用XMLHttpRequest对象请求一个php文件,这个php文件接收到信息,查询数 ...