首页 > 数据库技术 > 详细

MySQL 存储函数篇

时间:2019-08-29 22:41:28      阅读:83      评论:0      收藏:0      [点我收藏+]

目录

  • 什么是存储函数
  • 存储函数和存储过程的区别
  • 创建存储函数
  • 调用存储函数
  • 删除存储函数
  • 定义与实现完整性约束

 

1、什么是存储函数

  存储函数与存储过程一样,是由SQL语句和过程式语句组成的代码片段

 

2、存储函数和存储过程的区别

存储函数 存储过程
不能拥有输出参数 可以拥有输出参数
可以直接调用存储函数,不需要call语句 需要call语句调用存储过程
必须包含一条return语句 不允许包含return语句

 

 

 

 

 

3、创建存储函数

示例:在数据库中mysql_test中创建一个存储函数,要求该函数能根据给定的客户id号返回客户的性别,如果数据库中没有给定的客户id号,则返回"没有该客户".

用例表:customer(cust_id,cust_sex,cust_name);
->use mysql_test; ->delimiter $$ ->create function fn_name(cid int) //创建一个存储函数,题目要求我们输入id号判断性别,所以是int -> returns char(2) //返回性别,所以char类型 -> deterministic //为了提高where子句的性能加的 ->begin //接下来要写函数体了 -> declare sex char(2); //声明局部变量用来装性别 -> select cust_sex into sex from customer //把这个性别放进局部变量 -> where cust_id = cid; //判断id相符 -> if sex is null then //判断这个局部变量性别对应的属性 -> return(select 没有该客户); -> else if sex = then -> return(select ""); -> else return(select ""); -> end if; //用来结束else if的语句 -> end if; //用来结束if的语句 ->end $$ //用来结束存储函数

 

3、调用存储函数

//调用存储函数,举上面的例子

customer表的数据
(1,"男","zhangsan")
(2,"女","wangwu")
(3,"女","lisi")
(4,null,"wowo")

这里我有4条数据

->select fn_name(1)$$
->男 //输出结果

->select fn_name(2)$$
->女 //输出结果

->select fn_name(4)$$
->null //输出结果

 

4、删除存储函数

->drop function if exists fn_name $$

//指定要删除的存储函数的名称

 

5、定义与实现完整性约束

示例:在数据库mysql_test中创建一个商品订单表orders,该表包含订单号order_id,商品名order_product,商品类型order_product_type,客户id号cust_id,
订购时间order_date,价格order_price,数量order_amount。要求商品订单表orders中的所有订购客户信息均已在表costomers中记录在册
->use mysql_test ->cretate table orders ->( -> order_Id int not null auto_increment, -> order_product char(50) not null, -> cust_id int not null, -> order_date datetime not null, -> order_price double not null, -> order_amount int not null, -> primary key(order_id), -> foreign key(cust_id) -> references customers(cust_id) -> on delete restrict -> on update restrict ->); //restrict 限制策略 //cascade 级联策略 //set null 置空策略 //no action 不采取实施策略

 

MySQL 存储函数篇

原文:https://www.cnblogs.com/cheneyboon/p/11432095.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!