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建表语句如下。

sql 复制代码
CREATE TABLE splog (
	spbjlog char(8),
	spmclog varchar(20),
sjlog datetime,
Bz varchar(10));

实验准备:

sql 复制代码
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,实现可根据各种商品所属类别进行查询商品编号,名称,所属类别及价格:

sql 复制代码
#创建存储过程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':

sql 复制代码
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' then
 select '插入重复数据';
 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;

日志为空,目前没有重复插入数据

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

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

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

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

相关推荐
齐 飞18 分钟前
MongoDB笔记01-概念与安装
前端·数据库·笔记·后端·mongodb
云空19 分钟前
《Python 与 SQLite:强大的数据库组合》
数据库·python·sqlite
暮毅23 分钟前
10.Node.js连接MongoDb
数据库·mongodb·node.js
wowocpp27 分钟前
ubuntu 22.04 server 格式化 磁盘 为 ext4 并 自动挂载 LTS
服务器·数据库·ubuntu
成富1 小时前
文本转SQL(Text-to-SQL),场景介绍与 Spring AI 实现
数据库·人工智能·sql·spring·oracle
songqq271 小时前
SQL题:使用hive查询各类型专利top 10申请人,以及对应的专利申请数
数据库·sql
计算机学长felix1 小时前
基于SpringBoot的“校园交友网站”的设计与实现(源码+数据库+文档+PPT)
数据库·spring boot·毕业设计·交友
小码的头发丝、2 小时前
Django中ListView 和 DetailView类的区别
数据库·python·django
小兜全糖(xdqt)2 小时前
mysql数据同步到sql server
mysql·adb
Karoku0662 小时前
【企业级分布式系统】Zabbix监控系统与部署安装
运维·服务器·数据库·redis·mysql·zabbix