MySQL 存储过程(实验报告)

2024-05-25 14:44

本文主要是介绍MySQL 存储过程(实验报告),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、实验名称: 存储过程 

二、实验日期: 2024 年5  月 25 日

三、实验目的:

  • 掌握MySQL存储过程的创建及调用;

四、实验用的仪器和材料:

硬件:PC电脑一台;

配置:内存,2G及以上  硬盘250G及以上

软件环境:操作系统 windows7以上

数据库环境:MySQL5.7或MySQL8.0.20

五、实验步骤和方法

练习:(基于实验3的表结构及数据)

1、创建存储过程p_cx,实现可根据各种商品所属类别进行查询商品编号,名称,所属类别及价格。

2、创建一存储过程p_intbm,通过带参数的存储过程向表bmxx中插入一条数据,传入参数为bmbh,bmmc,并且如果插入主键重复数据,则将bmbh和bmmc插入错误记录表splog中,数据插入时间赋为当前日期,操作标志位赋上'insert'。错误记录表splog建表语句如下。

CREATE TABLE splog (spbjlog char(8),spmclog varchar(20),
sjlog datetime,
Bz varchar(10));

实验准备:

create database test11;
use test11;#创建商品信息表
create table spxx
(spbh char(8) not null primary key,
spmc varchar(20) not null,
sslb varchar(8) not null,
jg float(10,2) not null,
sl int(4)  not null
)ENGINE=InnoDB default charset=utf8;insert into spxx values('10000001','空调','电器',1500,10),('10000002','书包','文具',100,20),('10000003','卷纸','日用品',30,50);#创建部门信息表
create table bmxx
(bmbh char(8) not null primary key,
bmmc varchar(10) not null)ENGINE=InnoDB default charset=utf8;#部门信息表插入数据
insert into bmxx values('1001','业务'),('1002','技术'),('1003','售后'),('1004','管理');

   

六、实验结果或结论:即根据实验过程中所见到的现象和测得的数据,作出结论。

创建存储过程p_cx,实现可根据各种商品所属类别进行查询商品编号,名称,所属类别及价格:

#创建存储过程p_cx,实现可根据各种商品所属类别进行查询商品编号,名称,所属类别及价格。
delimiter //
create procedure p_cx(in csslb varchar(8))
begin
select spbh,spmc,sslb,jg from spxx where sslb = csslb;
end //
delimiter ;# 存储过程的调用alter
call p_cx('文具');
call p_cx('电器');

 

  创建一存储过程p_intbm,通过带参数的存储过程向表bmxx中插入一条数据,传入参数为bmbh,bmmc,并且如果插入主键重复数据,则将bmbh和bmmc插入错误记录表splog中,数据插入时间赋为当前日期,操作标志位赋上'insert':

delimiter //
create procedure p_intbm(in ibmbh char(8),ibmmc varchar(10))
Begin
declare done varchar(10);
DECLARE CONTINUE HANDLER FOR 1062 set done='false'; 
Insert into bmxx values(ibmbh,ibmmc);
If done='false' thenselect '插入重复数据';insert into splog values(ibmbh,ibmmc,current_time(),null);
end if;
set done='true';
end //
delimiter ;select * from bmxx;call p_intbm('1006','运维');  //重复运行几次,专门记录'插入重复数据'的日志表(splog)会记录下来
drop procedure p_intbm;select * from splog;
日志为空,目前没有重复插入数据

实验心得可写上实验成功或失败的原因,实验后的心得体会、建议等。

创建存储过程能够提高性能,存储过程在数据库中编译和存储,可以减少网络流量,提高性能。创建存储过程具有重用性:存储过程可以被多个应用程序调用,提高代码的重用性。可以提高安全性:通过存储过程,可以控制对数据库的访问权限,提高安全性。创建存储过程还能够简化复杂操作:存储过程可以包含复杂的业务逻辑,简化数据库操作。

在实践过程中,熟悉存储过程的语法和结构,了解存储过程的创建和执行过程,掌握存储过程中的语句格式,参数传递方式等。在编写存储过程前,需要明确存储过程的目的和实现的功能,并且规划好存储过程的整体逻辑。需要注意存储过程的性能问题:存储过程的性能直接影响数据库的整体性能,因此需要注意存储过程的优化,比如尽量减少数据库的访问次数,避免不必要的操作等。需要注意安全问题:存储过程中可能包含敏感数据,因此需要注意存储过程的安全性,比如对存储过程进行权限控制等。

创建存储过程需要一定的经验积累和技巧,因此需要多练习并不断总结经验。

这篇关于MySQL 存储过程(实验报告)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1001799

相关文章

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

python运用requests模拟浏览器发送请求过程

《python运用requests模拟浏览器发送请求过程》模拟浏览器请求可选用requests处理静态内容,selenium应对动态页面,playwright支持高级自动化,设置代理和超时参数,根据需... 目录使用requests库模拟浏览器请求使用selenium自动化浏览器操作使用playwright

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优

SQL Server 中的 WITH (NOLOCK) 示例详解

《SQLServer中的WITH(NOLOCK)示例详解》SQLServer中的WITH(NOLOCK)是一种表提示,等同于READUNCOMMITTED隔离级别,允许查询在不获取共享锁的情... 目录SQL Server 中的 WITH (NOLOCK) 详解一、WITH (NOLOCK) 的本质二、工作

MySQL 强制使用特定索引的操作

《MySQL强制使用特定索引的操作》MySQL可通过FORCEINDEX、USEINDEX等语法强制查询使用特定索引,但优化器可能不采纳,需结合EXPLAIN分析执行计划,避免性能下降,注意版本差异... 目录1. 使用FORCE INDEX语法2. 使用USE INDEX语法3. 使用IGNORE IND