MySQL中函数、游标、事件、视图
MySQL中函数、游标、事件、视图基本应用举例(代码)
MySQL中
function用户自定义函数
c,fun,fun是面向过程的实现方式
只能传入参数,或不传入参数,不能传出参数,必有返回值
函数中是不能有create table drop table之类的语句
与sp一样,db中object
begin end 相当于{}
(1)输入任意姓名,输出 hello+姓名+!
drop function if exists fun1;
delimiter //
create function fun1(a varchar(32))
returns varchar(32)
begin
declare x varchar(32);
set x=concat('hello',a,'!');
return x;
end //
delimiter ;
select fun1('张三');
-- (1)等同于(2)
(2)输入任意姓名,输出 hello+姓名+!
drop function if exists fun1;
create function fun1(a varchar(32))
returns varchar(32)
return concat('hello',a,'!'); -- 因为只有一条语句,所以省略了 begin end
select fun1('张三');
(3)求和
drop function if exists fun1;
delimiter //
create function fun1(a int,b int)
returns int
begin
declare c int;
-- set c=a+b;
select a+b into c;
return c;
-- return a+b;
end //
delimiter ;
select fun1(10,30);
(4)select fun1('zhangfei');->stu(stuName) 实现输入姓名,插入到stu表的stuName字段,并返回stu表的记录条数
drop function if exists fun1;
delimiter //
create function fun1(a varchar(32))
returns int
begin
declare x int;
insert into stu(stuName) select a;
select count(1) into x from stu;
return x;
end //
delimiter ;
select fun1('zhangfei');
(5)取输入字符串的前b个字符,并在其后加...输出,若输入字符串为空,则提示‘输入错误’,若输入字符串长度小于b,则直接输出字符串,若大于b,则截取前b个字符,并在其后加...输出
drop function if exists fun1;
delimiter //
create function fun1(a varchar(32),b int)
returns varchar(32)
begin
if isnull(a) || char_length(a)=0 then
return '输入错误';
elseif char_length(a)<=b then
return a;
else
return concat(left(a,b),'...');
end if;
end //
delimiter ;
select fun1('abcdef',3);
(6)输出a个*
drop function if exists fun1;
delimiter //
create function fun1(a int)
returns varchar(32)
begin
declare b int default 1; -- 1...5
declare s varchar(32) default '';
while b<=a
do
set s=concat(s,'*');
set b=b+1;
end while;
return s;
end //
delimiter ;
select fun1(5);
-- cursor游标(光标)
很少用,基本不用
对以后用php从一个表内将数据一条条取出来放网页上去显示
-- 什么是cursor
4个步骤
-- cursor,数据缓冲区
1.声明coursor
declare cur cursor for select stuID,stuName from stu oder by stuID;
2.打开coursor
open cur;
cursor有一个指针,默认就指在第一条
3.fetch
declare a int;
declare b varchar(32);
declare c varchar(32);
fetch cur into a,b,c;
select a,b,c;
fectch完数据,指针自动下移一行
while
close cur;
cursor 放在sp中用
drop procedure if exists sp1;
delimiter //
create procedure sp1()
begin
declare a int;
declare b varchar(32);
declare cur cursor for select stuID,stuName from aa order by stuID;
open cur;
-- fetch cur into a,b;
-- fetch cur into a,b; (有三条数据)
-- fetch cur into a,b;
-- select a,b;
-- close cur;
set @a=1;
select count(1) into @b from stu;
while @a<=@b
do
fetch cur into a,b;
select a,b;
set @a=@a+1;
end while;
close cur;
end //
delimiter ;
call sp1();
-- event事件
用的也较少 类似linux中的crontab (每天下午执行某事件) 一般用于定期执行某任务
drop event if exists ev1;
create event ev1
on schedule every 1 minute -- 每隔1分钟执行一次该事件
do
insert into aa select 5,'孙坚';
alter event ev1 disable; 使其停止执行
on schedule at now() 立即执行,就执行一次,事件不会保存下来
drop event if exists ev1;
delimiter //
create event ev1
on schedule at now() + interval 3 second -- 3秒后执行一次该事件,执行完后该事件消失
do
begin
insert into aa select 5,'孙坚';
insert inwo aa select 6,'e';
end//
delimiter ;
alter event ev1 disable;
alter event ev1 enable;
-- view 视图
-- 是一张虚拟表,
select * from v1;
-- data
view->table
-- 方便
-- 安全
stu(stuID,stuName,stuAge,stuAddr)
stuID,stuName->v1 -- 看需求
stu(stuID,stuName)
courses(coursesID,coursesName)
sc(stuID,coursesID,score)
create view v1
as
select stuName,coursesName,score
from stu,courses,sc
where sc.stuID=stu.stuID && sc.coursesID=courses.coursesID
select * from v1;
-- 比较复杂的查询做成view
-- 视图只用于看,显示,select
-- 当要进行数据修改插入什么的时候,直接修改基表
create table stu
(
stuID int,
stuName varchar(32),
stuAge int,
stuAddr varchar(32),
primary key(stuID)
)engine=innodb charset=utf8;
-- stuName,stuAge
drop view if exists v1;
create view v1
as
select stuName,stuAge from stu;
-- book(),author(),press
create table author
(
authorID int,
authorName varchar(32)
)engine=innodb charset=utf8;
create table press
(
pressID int,
pressName varchar(32)
)engine=innodb charset=utf8;
create table book
(
bookID int,
bookName varchar(32),
authorID int,
pressID int
) engine=innodb charset=utf8;
drop view if exists v1;
create view v1
as
select bookName,authorName,pressName
from book,author,press
where book.authorID=author.authorID && book.pressID=press.pressID;
select * from v1;
-- 根据需求,view只用来查数据
-- 要insert,update,delete就直接操作基表,而不是操作view
MySQL中函数、游标、事件、视图的更多相关文章
- [转]MySQL中函数CONCAT及GROUP_CONCAT
一.CONCAT()函数 CONCAT()函数用于将多个字符串连接成一个字符串. 使用数据表Info作为示例,其中SELECT id,name FROM info LIMIT 1;的返回结果为 +-- ...
- Mysql中函数和存储过程的区别
Mysql中函数和存储过程的区别 存储过程: 1. 可以写sql语句 2. inout,out构造返回值 3. 调用:call:存储过程名称 4. 可以 ...
- MySQL中函数、游标、事件、视图基本应用举例(代码)
MySQL中function用户自定义函数c,fun,fun是面向过程的实现方式只能传入参数,或不传入参数,不能传出参数,必有返回值函数中是不能有create table drop table之类的语 ...
- MySQL中函数CONCAT及GROUP_CONCAT
一.CONCAT()函数CONCAT()函数用于将多个字符串连接成一个字符串.使用数据表Info作为示例,其中SELECT id,name FROM info LIMIT 1;的返回结果为+----+ ...
- hive 中与mysql 中函数同名不同意的方法记录
max 函数 在hive中max函数是一个聚合函数,所以,而且返回值是double ,而且后面必须跟group by ,这个和mysql差异很大 Built-in Aggregate Function ...
- MySQL中函数CONCAT及GROUP_CONCAT函数的使用
一.CONCAT()函数 CONCAT()函数用于将多个字符串连接成一个字符串. 以数据表[user]作为实例: SELECT USER_NAME, SEX FROM USER WHERE USER ...
- Oracle中和mysql中函数的区别
oracle --> mysqlto_char(sysdate,'yyyy-mm-dd')-->date_format(s ...
- mysql中的游标使用
1.游标的作用及属性 游标的作用就是用于对查询数据库所返回的记录进行遍历,以便进行相应的操作:游标有下面这些属性: a.游标是只读的,也就是不能更新它: b.游标是不能滚动的,也就是只能在一个方向上进 ...
- JS中函数与事件
一.函数: 1.函数就是一个工具,通过一小段代码,完成某个功能: 2.函数的定义: function 函数名(){ ..... } 或者 : var 函数名 = function(){ ...... ...
随机推荐
- Hibernate实体映射配置(XML)简单三步完美配置
我们在使用Hibernate框架的时候,非常纠结的地方就是实体和表之间的映射,今天借助汤老师的思路写了小教程,以后配置不用纠结了! 第一步:写注释 格式为:?属性,表达的是本对象与?的?关系. 例:“ ...
- WCF服务上应用protobuf
WCF服务上应用protobuf Web api 主要功能: 支持基于Http verb (GET, POST, PUT, DELETE)的CRUD (create, retrieve, updat ...
- 第1章3节《MonkeyRunner源码剖析》概述:架构(原创)
天地会珠海分舵注:本来这一系列是准备出一本书的,详情请见早前博文“寻求合作伙伴编写<深入理解 MonkeyRunner>书籍“.但因为诸多原因,没有如愿.所以这里把草稿分享出来,所以错误在 ...
- JS获取渲染后的样式
一般我们利用element.style.属性来获取CSS的样式,而此方法只能获取标签内的样式,无法获取头部或引入的样式,因此,而我们又需要获取其样式,则我们可以使用:(其中element为标签,pro ...
- EA强大的绘图工具---设计数据库表格
关于EA这个优秀的软件是从师哥哪里听来的,自己瞎点了点,感觉也没什么.近期和和智福加上一个师哥合作敲机房收费系统时,想到之前听人说EA非常强大,便随便找了找关于EA使用的帮助手冊.果然惊喜-- 如题, ...
- 显示linux开机时间的脚本
最初的讨论是linux吧吧友@九十钩圈凯_ 发布的主题贴<加到自启动可以看开机时间的玩意> 并给出显示开机秒数的shell语句 [shell] [ $_UTED = 0 ] || noti ...
- JavaScript 多级联动浮动(下拉)菜单 (第二版)
JavaScript 多级联动浮动(下拉)菜单 (第二版) 上一个版本(第一版请看这里)基本实现了多级联动和浮动菜单的功能,但效果不是太好,使用麻烦还有些bug,实用性不高.这次除了修改已发现的问 ...
- 实例学习SSIS(二)--使用迭代
原文:实例学习SSIS(二)--使用迭代 导读: 实例学习SSIS(一)--制作一个简单的ETL包 实例学习SSIS(二)--使用迭代 实例学习SSIS(三)--使用包配置 实例学习SSIS(四)-- ...
- 如何将C#对象转化为JSON字符串
System.Web.Extensions.dll中类JavaScriptSerializer可以帮助我们把C#对象转化为JSON字符串. 有一个Person类 public class Person ...
- 30个HTML初学者建议
The most difficult aspect of running Nettuts+ is accounting for so many different skill levels. If w ...