第三次作业

1. 存储过程 avg_sal_a:按部门名称查询平均工资,结果存入变量 @a

sql

复制代码
DELIMITER // -- 临时修改语句结束符(避免存储过程中 ; 冲突)

CREATE PROCEDURE avg_sal_a(
    IN dept_name VARCHAR(20) -- 输入参数:部门名称
)
BEGIN
    -- 计算指定部门的平均工资,存入变量 @a
    SELECT AVG(e.salary) INTO @a -- INTO @a:将查询结果赋值给用户变量 @a
    FROM employees e
    INNER JOIN departments d 
      ON e.dept_id = d.dept_id -- 关联部门表和员工表
    WHERE d.dept_name = dept_name; -- 按输入的部门名称过滤
    
    -- 处理部门无员工的情况(平均工资为 NULL 时,设为 0)
    IF @a IS NULL THEN
        SET @a = 0;
    END IF;
END //

DELIMITER ; -- 恢复默认语句结束符
测试执行(部门名称测试参数为 "上海中心")

sql

复制代码
-- 1. 调用存储过程,传入部门名称"上海中心"
CALL avg_sal_a('上海中心');

-- 2. 查看变量 @a 中的平均工资结果
SELECT @a AS 上海中心平均工资;

2. 存储过程:按员工姓名查询其所在部门的最高工资,结果存入 @a

需求分析
  • 输入参数:员工姓名(emp_name
  • 输出参数:该员工所在部门的最高工资(存入变量 @a
  • 逻辑:先通过员工姓名找到其所属部门编号,再查询该部门的最高工资,赋值给 @a
存储过程创建语句(命名为 get_dept_max_sal

sql

复制代码
DELIMITER //

CREATE PROCEDURE get_dept_max_sal(
    IN emp_name VARCHAR(20) -- 输入参数:员工姓名
)
BEGIN
    -- 步骤1:通过员工姓名获取其部门编号;步骤2:查询该部门的最高工资,存入 @a
    SELECT MAX(e2.salary) INTO @a
    FROM employees e1 -- e1:用于查询输入员工的部门编号
    INNER JOIN employees e2 -- e2:用于查询该部门所有员工的工资
      ON e1.dept_id = e2.dept_id -- 关联同一部门的所有员工
    WHERE e1.emp_name = emp_name; -- 按输入的员工姓名过滤
    
    -- 处理员工不存在或部门无工资的情况
    IF @a IS NULL THEN
        SET @a = 0;
    END IF;
END //

DELIMITER ;
测试执行(示例:查询 "张三" 所在部门的最高工资)

sql

复制代码
-- 1. 调用存储过程,传入员工姓名(如"张三")
CALL get_dept_max_sal('张三');

-- 2. 查看变量 @a 中的最高工资结果
SELECT @a AS 张三所在部门最高工资;
  1. 查看已创建的存储过程: sql

    复制代码
    SHOW PROCEDURE STATUS LIKE 'avg_sal_a'; -- 查看第一个存储过程
    SHOW PROCEDURE STATUS LIKE 'get_dept_max_sal'; -- 查看第二个存储过程
  2. 删除存储过程(若需修改): sql

    复制代码
    DROP PROCEDURE IF EXISTS avg_sal_a;
    DROP PROCEDURE IF EXISTS get_dept_max_sal;
  3. 变量 @a 是用户全局变量,调用存储后可直接查询,若需多次测试,建议先重置变量:SET @a = NULL;

1. 创建学生表 student(含约束条件)

sql

复制代码
CREATE TABLE Student (
    Sno CHAR(10) PRIMARY KEY, -- 学号为主键(假设学号为10位字符,可根据实际调整长度)
    Sname VARCHAR(20) NOT NULL UNIQUE, -- 姓名非空且不能重名(UNIQUE约束)
    Ssex CHAR(2) NOT NULL CHECK (Ssex IN ('男', '女')), -- 性别只能是男/女(CHECK约束)
    Sage INT, -- 年龄(后续需修改为smallint)
    Sdept VARCHAR(20) DEFAULT '计算机' -- 所在系默认值为"计算机"
);

2. 修改 student 表中 Sage 字段的数据类型(int → smallint)

sql

复制代码
ALTER TABLE Student
MODIFY COLUMN Sage SMALLINT; -- MODIFY COLUMN 用于修改字段数据类型

3. 为 SC 表建立组合主键索引(Sno 升序 + Cno 升序,索引名 SC_INDEX)

sql

复制代码
-- 先确保SC表已创建(若未创建,需先执行创建表语句)
CREATE TABLE SC (
    Sno CHAR(10),
    Cno CHAR(4),
    Score DECIMAL(5,2), -- 成绩(假设保留2位小数,总长度5,如99.99)
    -- 组合主键(同时作为索引)
    PRIMARY KEY (Sno ASC, Cno ASC) -- 按Sno升序、Cno升序排序
);

-- 若SC表已存在,单独创建组合主键索引(题目要求索引名为SC_INDEX)
ALTER TABLE SC
ADD CONSTRAINT SC_INDEX PRIMARY KEY (Sno ASC, Cno ASC);

4. 创建视图 stu_info(查询姓名、性别、课程名、成绩)

sql

复制代码
CREATE VIEW stu_info AS
SELECT 
    s.Sname AS 姓名,
    s.Ssex AS 性别,
    c.Cname AS 课程名,
    sc.Score AS 成绩
FROM Student s
INNER JOIN SC sc ON s.Sno = sc.Sno -- 学生表与选课表通过学号关联
INNER JOIN Course c ON sc.Cno = c.Cno; -- 选课表与课程表通过课程号关联
相关推荐
好记忆不如烂笔头abc30 分钟前
RECOVER STANDBY DATABASE FROM SERVICE xxx,ORA-19909
数据库
writeone32 分钟前
数据库习题
数据库
廋到被风吹走1 小时前
【数据库】【Oracle】分析函数与窗口函数
数据库·oracle
陌北v12 小时前
为什么我从 MySQL 迁移到 PostgreSQL
数据库·mysql·postgresql
北辰水墨2 小时前
Protobuf:从入门到精通的学习笔记(含 3 个项目及避坑指南)
数据库·postgresql
JIngJaneIL2 小时前
基于java+ vue医院管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
予枫的编程笔记3 小时前
Redis 核心数据结构深度解密:从基础命令到源码架构
java·数据结构·数据库·redis·缓存·架构
信创天地3 小时前
信创国产化数据库的厂商有哪些?分别用在哪个领域?
数据库·python·网络安全·系统架构·系统安全·运维开发
JIngJaneIL3 小时前
基于java + vue校园跑腿便利平台系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
瀚高PG实验室3 小时前
highgo DB中数据库对象,模式,用户,权限之间的关系
数据库·瀚高数据库