《MySQL数据库》课件—08认识MySQL的存储过程
mysql存储过程和函数
Repeat语句语法格式 [begin_label:]repeat Statement_list Until search_condition End repeat[end_label] Repeat语句首先执行statement_list中的语句,然后 判断条件search_condition是否为真,倘若为真,则结束 循环,若不为真,继续循环。 Repeat先执行后判断,while先判断后执行。
9.1.1 创建存储过程
MySQL中,创建存储过程的基本形式如下: CREATE PROCEDURE sp_name ([proc_parameter[,...]]) [characteristic ...] routine_body
Sp_name:存储过程的名称,默认在当前数据库中创建 。这个名称应当尽量避免与MySQL的内置函数相同的名称
Declare cur_employee cursor for select name,age from employee;
2 打开光标 Open cursor_name
Open cur_employee;
3 使用光标 Mysql中使用fetch关键字来使用光标,语法形式 Fetch cur_name into var_name[,var_name…];
9.4 删除存储过程
Drop procedure [if exists] sp_name;
存储过程与存储函数联系与区别
存储过程与存储函数一样,都是由sql语句和过程式语 句所组成的代码片段,并且可以被应用程序和其他sql语句 调用。 区别: 存储函数不能拥有输出参数,因为存储函数自身就是 输出参数;而存储过程可以拥有输出参数。 可以直接对存储函数进行调用,而不需要使用call语句 ;而对存储过程的调用,需要使用call语句。 存储函数中必须包含一条return语句,而这条特殊的 sql语句不允许包含于存储过程中。
MYSQL存储过程专题-注释详解
MYSQL存储过程专题-注释详解原⽂链接,本⽂增加了注释、补充了部分运⾏错误、使⽤了不同MYSQL版本MySQL存储过程0.环境说明:软件版本mysql8.0navicat1.使⽤说明存储过程时数据库的⼀个重要的对象,可以封装SQL语句集,可以⽤来完成⼀些较复杂的业务逻辑,并且可以⼊参出参(类似于java中的⽅法的书写)。
创建时会预先编译后保存,⽤户后续的调⽤都不需要再次编译。
// 把editUser类⽐成⼀个存储过程public void editUser(User user,String username){String a = "nihao";user.setUsername(username);}main(){User user = new User();editUser(user,"张三");user.getUseranme(); //java基础还记得不}⼤家可能会思考,⽤sql处理业务逻辑还要重新学,我⽤java来处理逻辑(⽐如循环判断、循环查询等)不⾏吗?那么,为什么还要⽤存储过程处理业务逻辑呢?优点:在⽣产环境下,可以通过直接修改存储过程的⽅式修改业务逻辑(或bug),⽽不⽤重启服务器。
执⾏速度快,存储过程经过编译之后会⽐单独⼀条⼀条执⾏要快。
减少⽹络传输流量。
⽅便优化。
缺点:过程化编程,复杂业务处理的维护成本⾼。
调试不便不同数据库之间可移植性差。
-- 不同数据库语法不⼀致!2.准备:数据库参阅资料中的sql脚本;delimiter $$ --声明结束符3.语法#### 3.0 语法结构```sql-- 存储过程结构CREATE[DEFINER = user]PROCEDURE sp_name ([proc_parameter[,...]])[characteristic ...] routine_body-- 1. proc_parameter参数部分,可以如下书写:[ IN | OUT | INOUT ] param_name type-- type类型可以是MySQL⽀持的所有类型-- 2. routine_body(程序体)部分,可以书写合法的SQL语句 BEGIN ... END简单演⽰:-- 声明结束符。
mysql存储过程
mysql存储过程MySQL存储过程1. 存储过程简介我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(StoredProcedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它。
一个存储过程是一个可编程的函数,它在数据库中创建并保存。
它可以有SQL 语句和一些特殊的控制结构组成。
当希望在不同的应用程序或平台上执行相同的函数,或者封装特定功能时,存储过程是非常有用的。
数据库中的存储过程可以看做是对编程中面向对象方法的模拟。
它允许控制数据的访问方式。
存储过程通常有以下优点:(1).存储过程增强了SQL语言的功能和灵活性。
存储过程可以用流控制语句编写,有很强的灵活性,可以完成复杂的判断和较复杂的运算。
(2).存储过程允许标准组件是编程。
存储过程被创建后,可以在程序中被多次调用,而不必重新编写该存储过程的SQL语句。
而且数据库专业人员可以随时对存储过程进行修改,对应用程序源代码毫无影响。
(3).存储过程能实现较快的执行速度。
如果某一操作包含大量的Transaction-SQL 代码或分别被多次执行,那么存储过程要比批处理的执行速度快很多。
因为存储过程是预编译的。
在首次运行一个存储过程时查询,优化器对其进行分析优化,并且给出最终被存储在系统表中的执行计划。
而批处理的Transaction-SQL 语句在每次运行时都要进行编译和优化,速度相对要慢一些。
(4).存储过程能过减少网络流量。
针对同一个数据库对象的操作(如查询、修改),如果这一操作所涉及的Transaction-SQL语句被组织程存储过程,那么当在客户计算机上调用该存储过程时,网络中传送的只是该调用语句,从而大大增加了网络流量并降低了网络负载。
(5).存储过程可被作为一种安全机制来充分利用。
系统管理员通过执行某一存储过程的权限进行限制,能够实现对相应的数据的访问权限的限制,避免了非授权用户对数据的访问,保证了数据的安全。
MySql数据库基础PPT课件
MySql配置
Multifunctional Database(多功能数据库),此选项对事物性存储(InnoDB) 和非事务性(MyISAM)存储的存取速度都很快
Transactional Database only(事务型数据库),此选项主要优化了事务型 (InnoDB)存储,但是非事务型存储(MyISAM)也可以使用
8
数据库能够做什么
存储大量数据,方便检索和访问 保持数据信息的一致、完整 共享和安全 通过组合分析,产生新的有用信息
9
数据库的发展史
萌芽阶段——文件系统
使用磁盘文件来存储数据
初级阶段——第一代数据库
出现了网状模型、层次模型的数据库
中级阶段——第二代数据库
关系型数据库和结构化查询语言
高级阶段——新一代数据库
不同的地址!
存在不正确、不准确的数据,数据库“失去了完整性”
17
问题
用一个表能同时保存学生信息和考试成绩吗?为什么?
18
MySql安装需求
处理器
配置要求
最少:600-MHz 奔腾处理器 推荐:1GHZ或更高
内存
最小:512MB 推荐:1GB 或更大
磁盘容量
360 MB (典型安装)
MB
750 MB (完全安装)
部门编码 1 1 部门 人事管理部 市场营销部
16
数据库的基本概念 6-6
姓名
编码 11 12 15 13 14 15
姓名 阿兰
东方求败 张无忌 菜鸟特注
赵可 张无忌
地址
海淀黄庄菜园子 海淀龙王庙鬼楼
中关村大街3-201
海淀龙王庙树林 海淀龙王庙树林 中关村大街2-101
MySQL基本原理 ppt课件
15
MySQL复制原理
• MySQL Replication的基本原理是通过binlog复制应用的方式来还原数据。
• MySQL通过Server_id来识别binlog由哪台主机产生,因此即使双Master复制, 也不会出现binlog被重复应用
• 复制线程分为Slave IO和Slave SQL两个,Slave IO线程只负责注册到Master上, 读取binlog,然后解析到本地,Slave SQL线程只负责把Slave IO线程产生的可 执行SQL应用到本地。
dir=bundled –enable-assembler –enable-profiling –enable-local-in –with-readline
–with-pthread –with-embedded-server –with-client-ldflags=-all-static –with-
• MySQL结构层次 • MySQL处理流程 • 存储引擎机制
2021/3/26
MySQL基本原理 ppt课件
3
MySQL结构层次
2021/3/26
MySQL基本原理 ppt课件
4
MySQL处理流程
当客户端链接上mysql服务端时, 系统为其分配一个链接描述符thd, 用以描述客户端的所有信息,将作 为参数在各个模块之间传递。一个 典型的客户端查询在MySQL的主要 模块之间的调用关系如图所示:
wwwpenglixuncom整理课件内容概要mysql关键代码实现分析整理课件mysql体系架构存储引擎机制整理课件mysql结构层次整理课件mysql处理流程当客户端链接上mysql服务端时系统为其分配一个链接描述符thd用以描述客户端的所有信息将作为参数在各个模块之间传递
《MySQL数据库》教学讲解课件
MySQL支持多种操作系统,如Linux、Windows、Mac OS等,并提供 了多种编程语言的API接口,方便开发者进行数据库操作。
学习目标与要求
掌握MySQL数据库的基 本概念、数据类型和约束 等基础知识。
MySQL数据库安装与配置
详细介绍了MySQL数据库在不同 操作系统上的安装和配置方法,以 及常见问题的解决方案。
MySQL数据库高级应用
介绍了索引、视图、存储过程、触 发器等高级功能,以及MySQL数 据库的优化和备份恢复技术。
SQL语言基础
讲解了SQL语言的基本语法、数据 查询、数据插入、数据更新、数据 删除等操作,以及SQL函数和聚合 函数的使用方法。
安装MySQL数据库
下载MySQL安装包
从MySQL官方网站下载适合操作系统的 安装包。
配置安装选项
设置安装路径、数据存放目录、端口号 等。
安装类型选择
根据需求选择安装类型,如服务器版、 客户端版或开发版。
安装过程
按照安装向导逐步完成安装。
配置MySQL数据库
配置f或my.ini文件: 根据操作系统和MySQL版 本,编辑相应的配置文件, 设置字符集、缓冲池大小等
创建表
使用`CREATE TABLE`语句创建表,并 定义表结构,包括字段名称、数据类 型、约束等。
插入、更新和删除数据
插入数据
更新数据
使用`INSERT INTO`语句向表中插入数据, 可以插入单行数据或多行数据。
使用`UPDATE`语句更新表中的数据,可 以根据条件更新指定的字段。
第11章 MySQL存储过程与函数 第1节存储过程与函数简介 (1)
(2)创建函数
创建存储函数语法格式: create function sp_name ([func_parameter[,..]]) returns type [characteristic ..] routine_body
说明:在MySQL中,存储函数的使用方法与MySQL内部函数的 使用方法是一样的。换言之,用户自己定义的存储函数与MySQL 内部函数condition then statement_list [elseif search_condition then statement_list] … [else search_condition then statement_list] end if
数据库原理及MySQL应用 ——第十一章(第1节)
存储过程与函数简介
1.概念 2.存储过程和函数区别
1. 概念
一个存储过程是可编程的,它在数据库中创建并保存。它可以有SQL语句 和一些特殊的控制结构组成。
存储过程的优点: 存储过程增强了SQL语言的功能和灵活性; 存储过程允许标准组件是编程。 存储过程能实现较快的执行速度。 存储过程能过减少网络流量。 存储过程可被作为一种安全机制来充分利用。
【例19】删除存储过程studentcount
系统函数
1. 数学函数 2. 字符串函数 3. 日期和时间函数 4. 系统信息函数 5. 加密函数
具体使用 请参考教
材讲义
(6)repeat语句
repate语句是有条件控制的循环语句。 语法形式: [begin_label:] repeat statement_list until search_confition end repeat [end_label]
(7)while语句也是有条件控制的循环语句。
MySQL数据库应用实战教程 第5章 MySQL函数和存储过程
5.2.3 日期和时间函数
通过日期和时间函数可以获取当前日期、当前时间、年份、月份、 天、小时等关于日期的函数。日期和时间函数如表5.3所示。
表5.3 日期和时间函数
续表
常用的日期和时间函数如下。 (1)NOW():当前日期和时间,如2017-11-29 23:21:19。 (2)CURDATE():当前日期,如2017-11-29。 (3)CURTIME():当前时间,如23:22:49。 (4)YEAR(d):提取日期中的年份,如YEAR('2017-11-30')。 (5)MONTH(d):提取日期中的月份,如MONTH('20170819')。 (6)DAYOFYEAR(d):提取日期里一年中的第几天,如DAYOFYEAR ('2017-11-30')。
(11)DATE_ADD() :向后推时间。DATE_ADD(NOW(),INTERVAL 3 YEAR)表示当前时间往后推3年;DATE_ADD(NOW(),INTERVAL 3 MONTH)表示当前时间往后推3个月;DATE_ADD(NOW(),INTERVAL 3 DAY)表示当前时间往后推3天。
表5.1 数学函数
续表
常用的数学函数如下。 (1)CEILING(x):返回大于x的最小整数值,它是向上取整。 (2)FLOOR(x):返回小于x的最大整数值,它是向下取整。 (3)ROUND(x,y):返回参数x的四舍五入的有y位小数的值,进行 四舍五入,保留y位小数。 (4)TRUNCATE(x,y):返回数字x截短为y位小数的结果,不进行 四舍五入,直接保留y位小数。 (5)MOD(x,y):返回x/y的模,也是取余数,和x%y是等价的。
3.调用自定义函数
《mysql教程》课件
总结词
了解和掌握索引和约束的概念及作用, 以及如何在MySQL中创建和使用索引和 约束。
VS
详细描述
索引用于提高查询效率,通过在表的列上 创建索引,可以加快对数据的访问速度。 约束用于保证数据的完整性和一致性,常 见的约束有主键约束、外键约束、唯一约 束和检查约束等。在MySQL中,可以使 用CREATE INDEX语句创建索引,使用 ALTER TABLE语句添加约束。
的性能和响应速度。
04
MySQL安全和维护
用户和权限管理
用户管理
创建、删除用户,设置用户密码,为用户分 配权限等。
权限管理
为用户分配不同的数据库权限,如查询、插 入、更新、删除等。
角色管理
创建、删除角色,为角色分配权限,然后将 角色分配给用户。
访问控制
控制用户对数据库的访问,例如限制某些用 户只能访问特定的表或列。
数据插入、查询、更新和删除
总结词
掌握在MySQL中插入、查询、更新和删除数据的基本操作。
详细描述
插入数据使用INSERT INTO语句,查询数据使用SELECT语句,更新数据使用UPDATE语句,删除数据使用 DELETE FROM语句。这些操作是数据库管理中最常见的操作,需要熟练掌握。
索引和约束
视图和分区
要点一
视图
视图是一个虚拟表,基于SQL查询的结果集。视图可以用 于简化复杂的查询操作,隐藏表中的某些列或行,以及提 供数据安全性控制。
要点二
分区
分区是将表或索引分成多个较小的、更易于管理的片段的 技术。分区可以提高查询性能、管理大型表和索引的灵活 性,以及实现数据维护和备份的优化。
数据库设计和优化
2008年,MySQL被Sun Microsystems公司收 购。
在MySQL中使用存储过程进行数据分析和统计
在MySQL中使用存储过程进行数据分析和统计数据分析和统计在今天的信息时代变得越来越重要。
对于企业和组织来说,能够准确地了解和分析数据是决策制定的关键。
MySQL作为一种常用的关系型数据库管理系统,不仅提供了强大的数据存储和查询功能,还提供了存储过程的机制,可以用来进行更复杂的数据分析和统计。
一、存储过程简介存储过程是一组预编译的SQL语句集合,可以在数据库服务器上存储和执行。
它的优势在于可以减少网络开销,提高查询性能,同时也方便了维护和管理。
在MySQL中,通过CREATE PROCEDURE语句创建存储过程,然后通过CALL语句来执行。
为了演示存储过程在数据分析和统计中的应用,我们假设我们有一个包含大量销售数据的表,其中包含了销售日期、销售数量、产品价格等信息。
二、使用存储过程进行数据分析首先,我们可以使用存储过程来计算总销售额。
我们可以创建一个名为calculate_total_sales的存储过程,使用SUM函数来计算所有产品的销售额,并将结果返回。
```DELIMITER //CREATE PROCEDURE calculate_total_sales(OUT total DECIMAL(10, 2))BEGINSELECT SUM(quantity * price) INTO total FROM sales;END//DELIMITER ;```可以通过以下语句来执行该存储过程并获取结果:```CALL calculate_total_sales(@total);SELECT @total;```在上面的代码中,我们使用OUT参数将计算结果返回到变量total中,并在存储过程结束后使用SELECT语句将结果打印出来。
除了计算总销售额,我们还可以使用存储过程来进行更复杂的数据分析,比如计算每个月的平均销售额。
```DELIMITER //CREATE PROCEDURE calculate_average_sales_per_month()BEGINDECLARE month INT;DECLARE total_sales DECIMAL(10, 2);DECLARE total_count INT;DECLARE average_sales DECIMAL(10, 2);SET month = 1;SET total_sales = 0;SET total_count = 0;WHILE month <= 12 DOSELECT SUM(quantity * price), COUNT(*) INTO total_sales, total_count FROM salesWHERE MONTH(sale_date) = month;SET average_sales = total_sales / total_count;SELECT CONCAT('Month ', month, ': ', average_sales) AS result;SET month = month + 1;END WHILE;END//DELIMITER ;```上面的代码中,我们使用了一个循环来计算每个月的平均销售额。
存储过程和存储函数
游标中的数据保存在内存中,从其中提取数据的速度要比从数据表中直接 提取数据的速度快得多。
游标的使用包括声明游标、打开游标、读取游标、关闭游标。
常州信息职业技术学院
《MySQL数据库应用与管理》
2.创建存储过程和存储函数
➢ (6)游标的使用
示例8-13:创建一个存储过程up_getStuAvgGrade,通过游标操作来计算 某一学生的平均成绩。
常州信息职业技术学院
《MySQL数据库应用与管理》
3.调用存储过程和存储函数
➢ (1)调用存储过程
调用存储过程使用CALL语句。调用后,数据库系统将执行存储过程 中的语句。其语法格式如下:
常州信息职业技术学院
《MySQL数据库应用与管理》
4.查看存储过程和存储函数
使用SHOW STATUS语句查看存储过程和存储函数的状态
SHOW PROCEDURE STATUS [LIKE '存储过程名'] SHOW FUNCTION STATUS [LIKE '存储函数名']
常州信息职业技术学院
常州信息职业技术学院
《MySQL数据库应用与管理》
2.创建存储过程和存储函数
➢ (5)流程控制语句的使用
IF语句
IF <条件表达式1> THEN <语句块1> [ELSEIF <条件表达式2> THEN <语句块2>] … [ELSE <语句块n&据库应用与管理》
➢ (5)流程控制语句的使用
示例8-12:创建一个函数func_sum1,用来计算1+2+3+…+n的和,但不 包括同时能被3和7整除的数。使用WHILE和ITERATE语句来实现。
MySQL数据库课件(2020年7月整理).pdf
——用来控制存取许可、存取权限等;
——GRANT、REVOKE 等;
DDL( Data Definition Language,数据定义语言)
——用来建立数据库、数据库对象和定义其列
——CREATE 、DROP 等
事务控制语言(Tran Sac TIONAL Control Language, TCL)
2.选择“Custom”自定义安装,下一步
3.这里可以将不需要的安装删除,可以更改安装目录,下一步
4.单击“Install”按钮,开始安装
3
5.安装中,耐心等一会儿
6.这里是询问你是否要注册一个 My 的账号,或是使用已有的账号登陆 My ,一般不需
要了,点选“Skip Sign-Up”,按“Next”略过此步骤。
14.是否启用 TCP/IP 连接,设定端口,如果不启用,就只能在自己的机器上访问 My SQL 数据库了,我这 里启用,把前面的勾打上,Port Number:3306,在这个页面上,您还可以选择“启用标准模式”(Enable Strict Mode),这样 My SQL 就不会允许细小的语法错误。如果您还是个新手,我建议您取消标准模式以减少麻 烦。但熟悉 My SQL 以后,尽量使用标准模式,因为它可以降低有害数据进入数据库的可能性。按“Next”
据。 • 外键:外键用于关联两个表。 • 复合键:复合键(组合键)将多个列作为一个索引键,一般用于复合索引。 • 索引:使用索引可快速访问数据库表中的特定信息。索引是对数据库表中一列或多
列的值进行排序的一种结构。类似于书籍的目录。 • 参照完整性: 参照的完整性要求关系中不允许引用不存在的实体。与实体完整性是
4
8.进入配置过程
9.选择配置方式 选择配置方式,“Detailed Configuration(手动精确配置)”、“Standard Configuration
在MySQL中使用存储过程进行复杂数据操作与计算
在MySQL中使用存储过程进行复杂数据操作与计算随着数据量的不断增加,对数据库的复杂数据操作和计算需求也越来越多。
MySQL作为一种开源的关系型数据库管理系统,提供了存储过程的功能,能够通过编写存储过程来实现复杂的数据操作和计算。
存储过程是一组预定义的SQL语句集合,可以接受输入参数,并返回一个或多个结果。
通过使用存储过程,可以将复杂的数据操作和计算封装起来,提高数据库的性能和安全性。
下面将介绍在MySQL中使用存储过程进行复杂数据操作与计算的方法和技巧。
一、存储过程的创建和调用在MySQL中创建存储过程需要使用CREATE PROCEDURE语句,语法如下:CREATE PROCEDURE procedure_name([parameter_list])BEGIN-- 存储过程的SQL语句END;其中,procedure_name是存储过程的名称,parameter_list是输入参数的列表。
存储过程的调用可以使用CALL语句,语法如下:CALL procedure_name([parameter_list]);例如,创建一个简单的存储过程,用于查询员工的基本信息。
假设employee表结构如下:CREATE TABLE employee (id INT PRIMARY KEY,name VARCHAR(50),age INT,salary DECIMAL(10, 2));可以创建如下的存储过程来查询员工的基本信息:CREATE PROCEDURE get_employee_info(IN employee_id INT)BEGINSELECT * FROM employee WHERE id = employee_id;END;调用存储过程可以使用CALL语句,如下所示:CALL get_employee_info(1);二、存储过程的输入参数和输出参数存储过程可以接受输入参数,并返回一个或多个结果。
mysql教程PPT(无水印)
MySQL的应用场景
网站和Web应用
MySQL是许多流行的网站和Web应用 的数据库首选。
数据仓库和分析
MySQL可以用于构建数据仓库和进 行数据分析,支持大数据处理和数据
挖掘。
企业应用
MySQL适用于各种企业级应用,如 客户关系管理(CRM)、人力资源管 理和财务管理等。
游戏开发
MySQL可以用于游戏开发中的后端 数据库管理,支持游戏数据存储和查 询。
04 安全性
随着网络安全问题的日益突出, MySQL将加强数据加密、身份验 证等方面的安全措施,确保用户 数据的安全与隐私。
THANKS
日志记录
01
启用并配置MySQL的日志记录功能,记录用户的活动和数据库
的更改。
安全审计
02
定期审查和分析日志记录,发现潜在的安全威胁和异常行为。
日志轮换和管理
03
设置日志轮换计划,定期清理旧的日志文件,确保日志文件不
会无限制增长。
06
MySQL与其他数据库的比较 和未来发展
与其他数据库的比较
Oracle
表的创建和管理
创建表
使用`CREATE TABLE`语 句创建一个新的表。
删除表
使用`DROP TABLE`语 句删除一个存在的表。
修改表
使用`ALTER TABLE`语 句修改一个存在的表。
数据插入、查询、更新和删除
数据插入
使用`INSERT INTO`语句将数据 插入到表中。
数据查询
使用`SELECT`语句查询表中的 数据。
数据库的备份和恢复
备份
备份是创建数据库副本的过程,用于防止数据丢失和灾难恢复。MySQL支持多 种备份方法,如全备份、增量备份和差异备份。
MySQL数据库 课件 PPT 存储函数 动画版
某公司领导要在系统中查看研发部门 (research)的平均工资水平
emp表
任务一 不带参数 存储函数
任务二
dept表
select avg(sal) from emp join dept on emp.deptno=dept.deptno where dept.dname='research';
“两步走”策略:(1)先写出查询语句
文本替代法
情景导入 任务分解 任务实施 总结思考
创建带参数的存储函数 如何能够查看任意部门的平均工资水平呢?
任任务务一一
任务二 带参数 存储函数
CREATE FUNCTION getavg1( var_dname varchar(10) ) RETURNS 返回值int类型 begin
declare x int;
sfrSeolQemLc语team句vpg(jsoailn)
into dept
x on
emp.deptno=dept.deptno
where dept.dname='rveasre_adrncahm';e
return 返回x 值; end;
文本替代法——用变量替代文本
情景导入 任务分解 任务实施 总结思考
员工信息表(emp表)
任务分解
任务实施 总结思考 部门表(dept表)
如何能够查看任意部门的平均工资水平呢?
回顾导入 任务分解 任务实施 总结思考
任务分解
1 查看研发部门(research)的平均工资水平
不带参数的存储函数(重点)
2 查看任意部门的平均工资水平
带有传入参数的存储函数(难点)
情景导入 任务分解 任务实施 总结思考
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
• 任务1 初识MySQL存储过程 • 任务2 错误触发条件和错误处理程序 • 任务3 MySQL数据库中的游标 • 任务4 使用预处理SQL语句
任务1 初识MySQL存储过程 了解并创建存储过程
• 存储过程(Stored Procedure)是一组为了完成特定功能 的SQL语句集,经编译后存储在数据库中,用户通过指定 存储过程的名字并给定参数(如果该存储过程带有参数) 来调用执行它。
-- Байду номын сангаас参数,参数全为in(默认值)
DECLARE @t1 INT;
-- 有参数,有in,out,inout
DECLARE @t2 INT default 3;
call proc_name(1,2,@t1,@t2)
任务1 初识MySQL存储过程 存储过程调用
• 【例8-2】调用例8-1创建的名为demo的存储过程。
类型 [,[IN|OUT|INOUT] 参数名 数据类型…]])[特性...]过程体
• 例如: DELIMITER // CREATE PROCEDURE myproc(OUT s int) BEGIN SELECT COUNT(*) INTO s FROM students; END // DELIMITER ;
任务1 初识MySQL存储过程 了解并创建存储过程
• 存储过程的优点: • (1)增强SQL语言的功能和灵活性。 • (2)标准组件式编程。 • (3)较快的执行速度。 • (4)减少网络流量。 • (5)作为一种安全机制来充分利用。
任务1 初识MySQL存储过程 了解并创建存储过程
• MySQL存储过程的创建语法: • CREATE PROCEDURE 过程名([[IN|OUT|INOUT] 参数名 数据
任务1 初识MySQL存储过程 存储过程调用
• 调用存储过程需要用call命令和存储过程名以及一个括号,括号里面根 据需要,加入参数,参数包括输入参数、输出参数、输入输出参数。 具体的调用方法可以参看下面例子。
例如:
call proc_name()
-- 无参数
call proc_name(1,2)
• 在调用demo存储过程执行之前,先设定了变量p_in的值为1,然后调 用了存储过程demo,而该存储过程的内容就是修改并显示p_in的值, 因此在输出段看到出现了两次p_in的值,第一次是存储过程刚开始执 行时第一条语句的结果,显示p_in的值;第二次是存储过程中第三条 语句的结果,显示了p_in被修改之后的新值。
任务1 初识MySQL存储过程 了解并创建存储过程
• MySQL数据库默认以";"为分隔符,如果没有声明分割符, 则编译器会把存储过程当成SQL语句进行处理,编译过程 会报错。
• 所以要事先用“DELIMITER //”语句修改当前段分隔符为 “//”,也就是说,此语句之后的所有语句以“//”作为分隔符, 让编译器把第一次出现的“//”和第二次出现的“//”之间的全 部内容当做存储过程的代码,不会执行这些代码。
• 【例8-3】创建demo_out_parameter存储过程,参数采用OUT类型。
MySQL > DELIMITER // MySQL > CREATE PROCEDURE demo_out_parameter(OUT p_out int) -> BEGIN -> SELECT p_out; -> SET p_out=2; -> SELECT p_out; -> END; -> // MySQL > DELIMITER ;
• 当存储过程执行完毕,又一次调用 p_in变量的值,发现该变量的值仍 然是1,这是因为demo存储过程在设定参数的时候已经确定了参数为 IN,因此无论存储过程内部如何对p_in变量进行修改,一旦存储过程 退出,p_in变量的值都将恢复到存储过程执行之前的状态。
任务1 初识MySQL存储过程 存储过程调用
INOUT:表示该参数在调用时指定,并且可以被改变 和返回。
任务1 初识MySQL存储过程 了解并创建存储过程
存储过程的过程体开始与结束使用BEGIN与END进行标识。举例如下: 【例8-1】in参数实例 MySQL > DELIMITER // -- 修改结束符 MySQL > CREATE PROCEDURE demo(IN p_in int) -- 定义带参数的 存储过程 -> BEGIN -> SELECT p_in; -> SET p_in=2; -> SELECT p_in; -> END; -> // MySQL > DELIMITER ;
• 而后面的“DELIMITER ;”意为把分隔符还原为默认的“;”(注 意在DELIMITER与;之间要有一个空格)。
任务1 初识MySQL存储过程 了解并创建存储过程
• 存储过程的参数类型:
IN:表示该参数值必须在调用存储过程时指定,在存 储过程中这个值是不能被返回的。
OUT:表示该参数的值可以被存储过程改变,并且可 以返回。
MySQL > SET @p_in=1; MySQL > CALL demo(@p_in); +------+ | p_in | +------+ | 1| +------+
MySQL> SELECT @p_in; +-------+ | @p_in | +-------+ |1 | +-------+
+------+ | p_in | +------+ | 2| +------+
任务1 初识MySQL存储过程 存储过程调用
• 在例8-2中,先是创建了一个名为demo的存储过程,该存储过程有一 个参数为p_in,这个参数是int类型,代表了一个整数,并且前面由IN 来修饰,说明该参数在存储过程执行过程中,不能作为返回值。
任务1 初识MySQL存储过程 了解并创建存储过程
• MySQL数据库中的存储过程和函数中允许包含DDL(Data Definition Language数据库模式定义语言,是用于描述 数据库中要存储的现实世界实体的语言)语句,也允许在存 储过程中执行提交(commit,即确认之前的修改)或者 回滚(rollback,即放弃之前的修改),但是存储过程和 函数中不允许执行LOAD DATA INFILE 语句。此外,存储 过程和函数中可以调用其他存储过程或者函数。。