第三次作业

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; -- 选课表与课程表通过课程号关联
相关推荐
Dragon online8 小时前
数据分析师成长之路--从SQL恐惧到数据掌控者的蜕变
数据库·sql
VX:Fegn08959 小时前
计算机毕业设计|基于springboot + vue音乐管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·课程设计
一招定胜负9 小时前
navicat连接数据库&mysql常见语句及操作
数据库·mysql
热心市民蟹不肉9 小时前
黑盒漏洞扫描(三)
数据库·redis·安全·缓存
chian_ocean9 小时前
openEuler集群 Chrony 时间同步实战:从零构建高精度分布式时钟体系
数据库
Databend10 小时前
构建海量记忆:基于 Databend 的 2C Agent 平台 | 沉浸式翻译 @ Databend meetup 上海站回顾及思考
数据库
αSIM0V10 小时前
数据库期末重点
数据库·软件工程
2301_8002561110 小时前
【第九章知识点总结1】9.1 Motivation and use cases 9.2 Conceptual model
java·前端·数据库
不会写程序的未来程序员10 小时前
Redis 的核心机制(线程模型、原子性、Bigkey、单线程设计原因等)
数据库·redis
编程圈子10 小时前
灵动微MM32 芯片串口升级OTA功能开发5. 写入FLASH与跳转功能
数据库