delimiter $$
create function fn_liangzifunction() returns int
no sql
begin
set @row_no = @row_no + 1;
return @row_no;
end;
$$
delimiter ; delimiter $$
create function fn_get_name(student_num int) returns char(50)
reads sql data
begin
declare student_names char(50);
select student_name into student_names from student where student_no = student_num;
return student_names;
end;
$$
delimiter ; #将查询结果赋予变量。 delimiter $$
create function fn_get_choose_count(student_no1 int) returns int(50)
reads sql data
begin
declare choose_num int(50);
select count(*) into choose_num from choose where student_no = student_no1;
return choose_num;
end;
$$
delimiter ; delimiter $$
create function fn_get_name(no int,role char(50)) returns char(50)
reads sql data
begin
declare name char(50);
if('student'=role) then
select student_name into name from student where student_no=no;
elseif('teacher'=role) then
select teacher_name into name from teacher where teacher_no=no;
else set name = '输入有误';
end if;
return name;
end;
$$
delimiter ; #if else
delimiter $$
create function fn_get_name(no int,role char(20)) returns char(20)
reads sql data
begin
declare name char(20);
if(role='student') then
select student_name into name from student where student_no=no;
elseif(role='teacher') then
select teacher_name into name from teacher where teacher_no=no;
else set name='输入错误';
end if;
return name;
end;
$$
delimiter ; #switch case delimiter $$
create function fn_get_week(week_no int) returns char(20)
no sql
begin
declare week char(20);
case week_no
when 0 then set week = '星期一';
when 1 then set week = '星期二';
when 2 then set week = '星期三';
when 3 then set week = '星期四';
when 4 then set week = '星期五';
else set week = '今天休息';
end case;
return week;
end;
$$
delimiter ; #根据现在的时间判断问候语 delimiter $$
create function fn_get_hello(time int) returns char(20)
no sql
begin
declare hello char(20);
if(time < 9) then
set hello = '早上好';
elseif( 9 < time and time <= 12) then
set hello = '上午好';
elseif( 12 < time and time <= 18) then
set hello = '下午好';
elseif(18 < time and time < 22) then
set hello = '晚上好';
else
set hello = '晚安';
end if;
return hello;
end;
$$
delimiter ; #练习switch case 语句 delimiter $$
create function fn_get_myweek(day int) returns char(50)
no sql
begin
declare weekname char(50);
case day
when 1 then set weekname = '星期一';
when 2 then set weekname = '星期2';
when 3 then set weekname = '星期3';
when 4 then set weekname = '星期4';
when 5 then set weekname = '星期5';
else set weekname = '星期日';
end case;
return weekname;
end;
$$
delimiter ; #while语句
#和其他编程一样,当条件表达式值为true时,就一直执行循环体,直到条件表达式为false。 delimiter $$
create function fn_get_mysum(num int) returns int
no sql
begin
declare sum int default 0;
declare start int default 0;
while start < num do
set start = start + 1;
set sum = sum + start;
end while;
return sum;
end;
$$
delimiter ; #while中的内部控制语句
#leave 相当于php循环中的break了。
# 至于下面的add_num,相当于给while的循环起一个名字。 delimiter $$
create function fn_get_sum1(n int) returns int
no sql
begin
declare sum int default 0;
declare start int default 0;
add_num : while true do
set start = start + 1;
set sum = sum + start;
if(start = n) then
leave add_num;
end if;
end while add_num;
return sum;
end;
$$
delimiter;

Mysql学习笔记(七)mysql编程基础之自定义函数。的更多相关文章

  1. java学习笔记15--多线程编程基础2

    本文地址:http://www.cnblogs.com/archimedes/p/java-study-note15.html,转载请注明源地址. 线程的生命周期 1.线程的生命周期 线程从产生到消亡 ...

  2. java学习笔记14--多线程编程基础1

    本文地址:http://www.cnblogs.com/archimedes/p/java-study-note14.html,转载请注明源地址. 多线程编程基础 多进程 一个独立程序的每一次运行称为 ...

  3. 吴裕雄--天生自然MySQL学习笔记:MySQL 安装

    所有平台的 MySQL 下载地址为: MySQL 下载:https://dev.mysql.com/downloads/mysql/ 注意:安装过程我们需要通过开启管理员权限来安装,否则会由于权限不足 ...

  4. 吴裕雄--天生自然MySQL学习笔记:MySQL GROUP BY 语句

    GROUP BY 语句根据一个或多个列对结果集进行分组. 在分组的列上我们可以使用 COUNT, SUM, AVG,等函数. GROUP BY 语法 SELECT column_name, funct ...

  5. 吴裕雄--天生自然MySQL学习笔记:MySQL 运算符

    要介绍 MySQL 的运算符及运算符的优先级. MySQL 主要有以下几种运算符: 算术运算符 比较运算符 逻辑运算符 位运算符 算术运算符 MySQL 支持的算术运算符包括: 在除法运算和模运算中, ...

  6. 吴裕雄--天生自然MySQL学习笔记:MySQL 导入数据

    1.mysql 命令导入 使用 mysql 命令导入语法格式为: mysql -u用户名 -p密码 < 要导入的数据库数据(runoob.sql) 实例: # mysql -uroot -p12 ...

  7. 吴裕雄--天生自然MySQL学习笔记:MySQL 处理重复数据

    有些 MySQL 数据表中可能存在重复的记录,有些情况允许重复数据的存在,但有时候我们也需要删除这些重复的数据. 防止表中出现重复数据 可以在 MySQL 数据表中设置指定的字段为 PRIMARY K ...

  8. 吴裕雄--天生自然MySQL学习笔记:MySQL 临时表

    MySQL 临时表在我们需要保存一些临时数据时是非常有用的.临时表只在当前连接可见,当关闭连接时,Mysql会自动删除表并释放所有空间. MySQL临时表只在当前连接可见,如果使用PHP脚本来创建My ...

  9. 吴裕雄--天生自然MySQL学习笔记:MySQL 事务

    MySQL 事务主要用于处理操作量大,复杂度高的数据.比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成 ...

  10. 吴裕雄--天生自然MySQL学习笔记:MySQL UNION 操作符

    MySQL UNION 操作符用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中.多个 SELECT 语句会删除重复的数据. 语法 MySQL UNION 操作符语法格式: SELECT ...

随机推荐

  1. .net程序员转行做手游开发经历(二)

    上篇主要介绍自己个人的经历,这篇主要讲下学习新语言的过程. 上次说到最终选择的语言是swift,框架用spritekit,上次有网友对为什么选择用这俩呢,为什么不用cocos和unity呢,cocos ...

  2. PC互联网和移动互联网的本质差别

    网一代,我们先称为PC互联网,这大约可以从2010年作为分界,然后就是基于手机,及可穿戴的移动互联网. 在PC时代,软件都很庞大复杂,甚至客端端和网页混合,比如常见的桌面软件,Office及Photo ...

  3. sql 几点记录

      1       With子句 1.1     学习目标 掌握with子句用法,并且了解with子句能够提高查询效率的原因. 1.2     With子句要点 with子句的返回结果存到用户的临时表 ...

  4. The Lifecycle and Cascade of WeChat Social Messaging Groups-www2016-20160512

    分析性论文: 分析并预测微信群的生命周期,以及群成员的邀请模式. 参考资料:http://www.360doc.com/content/16/0423/11/26166517_553076725.sh ...

  5. java中的枚举类型

    枚举类型是那些字段由一组固定常量组成的类型.常见的例子有:东南西北四个方向,星期几等. 所有枚举类型都隐式继承java.lang.Enum类型,因为java不支持多重继承,所以枚举不能继承其他任何类. ...

  6. memcached安装配置

    简述: memcached,开源的分布式缓存数据系统.高性能的NOSQL . Linux 一.环境配置与安装 01.编译准备环境 yum install -y gcc make cmake autoc ...

  7. RHCE认证考试教材

    前段时间考RHCE7,顺便给大家分享下RHCE6.7的中文教材!毕竟此书是官方的培训教材,还是值得看看!RHEL6.7承前启后的,给个赞! 下载:http://pan.baidu.com/s/1nu9 ...

  8. 软件工程(FZU2015)增补作业

    说明 张老师为FZU软件工程2015班级添加了一次增补作业,总分10分,deadline是2016/01/01-2016/01/03 前11次正式作业和练习的迭代评分见:http://www.cnbl ...

  9. 第十五章:输入和输出(I/O)

    一:流分类 抽象基类:InputStream和Reader        抽象类不能用于创建模板哦! OutputStream和Writer 方向:  以内存为中心! 输入流(读) 输出流(写) 数据 ...

  10. RabbitMQ 工作队列

    创建一个工作队列用来在工作者(consumer)间分发耗时任务. 工作队列的主要任务是:避免立刻执行资源密集型任务,然后必须等待其完成.相反地,我们进行任务调度:我们把任务封装为消息发送给队列.工作进 ...