您的位置:首页 > 房产 > 家装 > 最好玩的网站_中国检验认证集团北京有限公司_关键词seo是什么意思_最有吸引力的营销模式

最好玩的网站_中国检验认证集团北京有限公司_关键词seo是什么意思_最有吸引力的营销模式

2025/1/14 1:16:43 来源:https://blog.csdn.net/qq_42217078/article/details/143374200  浏览:    关键词:最好玩的网站_中国检验认证集团北京有限公司_关键词seo是什么意思_最有吸引力的营销模式
最好玩的网站_中国检验认证集团北京有限公司_关键词seo是什么意思_最有吸引力的营销模式

/*
一、实验要求:
1. 理解存储过程的概念
2. 掌握存储过程的语法格式、使用方法
3. 掌握存储过程的创建、执行
二、实验前提: 构建student表
*/

show procedure status where db="ceshi";#查看ceshi 数据库下所有的存储过程


drop table if exists student;

Create table student
(Id varchar(255), #学号
Name varchar(255), #姓名
Roomid varchar(255), #班级
Sex char(1), #性别
Degree varchar(3) );#成绩;


Insert into student values('1','amy','8','0','65');
Insert into student values('2','bob','4','1','80');
Insert into student values('3','candy','6','0','70');
Insert into student values('4','danny','8','1','90');
Insert into student values('5','edward','8','1','95');
Insert into student values('6','frank','7','1','100');

select * from student;

-- 1:创建一个存储过程,实现查询表student中的记录信息,并执行存储过程

drop procedure if exists x1;

create procedure x1() #无参数,是括号内无参数
begin
select * from student ;
end

call x1();

-- 2:创建一个存储过程,根据给定的学生学号返回该学生的姓名
drop procedure if exists x2;

create  procedure  x2(in xuehao varchar(255)) 
begin 
select Name from student 
where ID =  xuehao;
end

call x2(1);
call x2(2);

-- 3:创建一个存储过程,根据所给的班级的编号,统计该班人数,并将人数以输出变量返回给用户
drop procedure if exists x3;

create procedure x3(in banjihao varchar(255) )
begin 
select count(Id) 班级人数 from  student 
where Roomid = banjihao;
end

call x3(8)

show create procedure x3 #查看常见的存储过程

-- 4:创建一个存储过程,根据所给的学号查询该学生的考试分数是否超过了85分, 若超过则输出“ 考得好”, 否则输出 “考得不好”
drop procedure if exists x4;

create procedure x4(in chengji int(3),out jieguo varchar(255) )
begin 
select  if((degree+0) > 85,"考得好","考得不好") 考试状态  into jieguo  from student
where Id = chengji;
end 

call x4(3,@jieguo);
select @jieguo


call x4(5,@jieguo);
select @jieguo

select * from student
-- 实验5:创建一个存储过程,对表student增加两条记录
drop procedure if exists x5

create procedure x5()
begin
Insert into student values('7','make','7','0','98'),('8','andy','5','1','99');
select * from  student ;
end

call x5()

-- 6:请撰写一个存储过程,输出各班学生的平均成绩
drop procedure if exists x6;


create procedure x6()
begin
select Roomid 班级, round(avg(degree),2) 班级平均成绩 from student
group by Roomid order by 班级;
end 

call  x6()


#-----各自输入输出查班级均分--------
drop  procedure if exists x06

create procedure x06(in banjihao varchar(255))
begin
select Roomid 班级, round(avg(degree),2) 班级平均成绩  from student
group by Roomid having Roomid  = banjihao ;
end

call x06(4)


#--加上out 
delimiter //
drop  procedure if exists x061

create procedure x061(in banjihao varchar(255),out gebanjunfen varchar(255))
begin
select Roomid 班级,round(avg(degree),2) 班级平均成绩 into gebanjunfen from student
group by Roomid having Roomid  = banjihao ;
end
//


call x061(4,@gebanjunfen)
call x061(7,@gebanjunfen)
call x061(8,@gebanjunfen)

-- 报错 :The used SELECT statements have a different number of columns

#---加out一列查找
drop  procedure if exists x062

create procedure x062(in banjihao varchar(255),out gebanjunfen varchar(255))
begin
select round(avg(degree),2) 班级平均成绩 into gebanjunfen from student
where Roomid  = banjihao ;
end
//


call x062(4,@gebanjunfen)

select @gebanjunfen
#---------


-- 7:请撰写一个存储过程,能根据用户输入的学号,输出学生的姓名、性别到两个参数变量中,以供其它程序使用


drop  procedure if exists  x7

create procedure x7(in xuehao int(3))
begin 
select Name 姓名,Sex 性别  from student
where Id = xuehao ;
end 


call x7(1)


#-----------加上out-----------
drop  procedure if exists  x71
create procedure x71(in xuehao int(3),out xingming varchar(255) ,out xingbie char(1) )
begin 
select Name 姓名,Sex 性别 into xingbie from student
where Id = xuehao ;
end 

call x71(1,@xingming,@xingbie)
-- 报错 :The used SELECT statements have a different number of columns
select @xingbie


delimiter //
drop procedure if exists cc7;
create procedure cc7(in sid varchar(255),out sname varchar(255),out gender varchar(255))
begin
    select
    name into sname
    from student
    where id = sid;
    
    select
  sex into gender
    from student
    where id = sid;
end
//

call cc7(1,@sname,@gender);
select @sname, @gender;


8:撰写一个存储过程,根据用户输入的学号,输出学生性别,成绩两个参数放到新表temp中
/*
Create table temp(Sex varchar(255),Degree varchar(255));

两张表的字段一致,插入数据:
方法一:insert into 目标表 select * from 来源表;#插入全部数据
方法二:insert into 目标表(字段 )select 字段1,字段2 from 来源表。
*/
 
select * from  temp  desc student;


drop procedure if  exists x8

create procedure x8(in xuehao varchar(255))
begin
-- drop table if exists temp;
create table temp(Sex varchar(255),Degree varchar(255));
insert into temp  (select Name 姓名,Sex 性别 from student
where Id = xuehao);
select * from temp;
end

call  x8(3)
call  x8(8)

select * from temp
-- 9:请撰写一个存储过程,求1+2+3+…x的值。
-- 请撰写一个存储过程,求0+2+4+…x的值。
-- 请撰写一个存储过程,求1+3+5+…x的值。

drop procedure if exists h1

-- create procedure h1(in x int(3),in y int(3))
-- set @x=1

delimiter //
create  procedure h1(inout x int)
BEGIN
  set x=x+1;
END
//
set @x=1
call h1(@x)
select @x


drop procedure if exists h1

delimiter //
create  procedure h1(in x int,in y int)
BEGIN
-- set @x=1
-- set @y=10
-- declare i int default 1
-- while(i<=y) do
--   set x=x+1;
-- end while

set x=(1+y)*y/2;
END
//

call h1(@x)
select @x

#使用公式法
delimiter //
create  procedure h1(in y int)
BEGIN
declare x int;
set x=(1+y)*y/2;
select  X;
END
//

call h1(10)


#设置参数和后的公式

delimiter //
drop procedure if exists h1;
create  procedure h1(in y int,inout  m int)
BEGIN
declare i int default 1;
while(i<=y) do
   set m=m+i;
   set i=i+1;
end while;
END
//
set  @m=0
call h1(5,@m)
select  @m


#设置起始参数和运行次数参数1+2+3
delimiter //
drop procedure if exists h1;
create  procedure h1(in  x int,in y int,inout  m int)
BEGIN
while(x<=y) do
   set m=m+x;
   set x=x+1;
end while;
END
//


set  @m=0
call h1(2,5,@m)

call h1(3,5,@m)
select  @m

#设置起始参数和运行次数参数0+2+4
delimiter //
drop procedure if exists h1;
create  procedure h1(in  x int,in y int,inout  m int)
BEGIN
while(x<=y) do
   set m=m+x;
   set x=x+2;
end while;
END
//
set  @m=0
call h1(0,5,@m)
select  @m


#设置起始参数和运行次数参数1+3+5
delimiter //
drop procedure if exists h1;
create  procedure h1(in  x int,in y int,inout  m int)
BEGIN
while(x<=y) do
   set m=m+x;
   set x=x+2;
end while;
END
//


set  @m=0
call h1(1,5,@m)

select @m


#设置起始参数和运行次数参数(分情况3种)
delimiter //
drop procedure if exists h1;
create  procedure h1(in  i int,in  x int,in y int,inout  m int)
BEGIN

#1+2+3
if(i = 1) then
    while(x<=y) do
         set m=m+x;
         set x=x+1;
    end while;

#0+2+4
else if(i = 2)  then
        while(x<=y) do
            set m=m+x;
            set x=x+2;
        end while;
        
#1+3+5
else if(i = 3)  then
        while(x<=y) do
            set m=m+x;
            set x=x+2;
        end while;
    
end if;
end if;
end if;
END
//

#测试累加情况1:
set  @m=0
call h1(1,1,5,@m) #1+2+3+4+5
select  @m

#测试累加情况2:
set  @m=0
call h1(2,0,5,@m)#0+2+4
select  @m

#测试累加情况3:
set  @m=0
call h1(3,1,5,@m)#1+3+5
select  @m

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com