mysql练习5

    数据准备    
    创建两张表:部门(dept)和员工(emp),并插入数据,代码如下    
    create table dept(    
    dept id int primary key auto increment comment'部门编号',    
    dept_name char(20)comment'部门名称'    
    );    
   insert into dept (dept_name) values('销售部'),('财务部'),('生产部'),('人事部');    



    create table emp(    
    emp_id int primary key auto_increment comment'员工号',    
emp name char(20) not null default '' comment'员工姓名', gender char(2) not null default '男'comment'性别',
birth datetime not null default'1990-1-1'comment'出生日期', salary decimal(10,2) not null default 0 comment'工资',
    address varchar(200) not null default '' comment'通讯地址',    
  dept_id int comment'部门编号'    
    );    



    create index idx name on emp(emp name);    
    create index idx birth on emp(birth);    
    create index idx deptid name on emp(dept id,emp name);    



   insert into emp (emp_name,gender,birth,salary,address,dept_id)    
    values('张晓红','女','1980-1-23',5800,'河南省郑州市中原路10号',1),    
    ('张静静','女','1987-10-3',5400,'河南省新乡市平原路38号',1),    
    ('王云飞',男','1992-11-15',5600,'河南省新乡市人民路28号',1),    
('王鹏飞',男','1987-10-1',6800,'河南省新乡市东明大道12号',1),

    '王大鹏',男,1989-2-11',5900,'河南省郑州市东风路15号',1),    
    ('王萌萌',    女','1986-12-30',5000,'河南省开封市五一路14号',2),    
    ('王大光','男','1988-11-8',6200,'河南省开封市八一路124号'2),    
    ('王小明',男','1998-1-3',4800,'河南省驻马店市雪松路128号',2),    
    ('王娜娜',    女    '1994-3-5',5200,'河南省驻马店市车站路2号',2),    
    ('刘云飞',男','1992-8-13',6800,'河南省南阳市民生路255号',3),    
    ('张陆军',男','1991-9-6',6200,'河南省南阳市张仲景路14号',3);    


   

1、创建视图v_emp_dept_id 1,查询销售部门的员工姓名和家庭住址

create v_emp_dept_id_1

as select emp_name,address

from emp inner join dept

on dept.dept_id = emp.dept_id

where emp.dept_id = (select dept_id from dept where dept_name = '销售部) ;

2、创建视图vempdept,查询销售部门员工姓名和家庭住址及部门名称。

create view v_emp_dept

as select emp_name,address,dept.dept_name

from emp inner join dept

on dept.dept_id = emp.dept_id

where dept_id = (select dept_id from dept where dept_name = '销售部') ;

3、创建视图v_dept_emp_count(dept_name,emp_count,avg_salay),统计每个部门人数并计算平均工资

create view v_dept_emp_count(dept_name,emp_count,avg_salay)

as select emp_name,count(1),avg(salary)

from emp inner join dept

on dept.dept_id = emp.dept_id

group by emp.dept_id;

4、修改视图v_emp_dept,查询销售部门员工姓名、家庭住址、工资和部门名称。

alter view v_emp_dept as

select emp.emp_name,emp.address,emp.salary,dept.dept_name

from   emp inner join dept

on dept.dept_id = emp.dept_id;

5、查看视图名称: 查看视图结构; 查看创建视图语句;

6、删除以上三个视图。

存储过程作业:

1、创建一个提取emp表所有员工工资和的存储过程s1

\d @

create procedure s1()

begin

select sum(salary) from emp;

end @

\d ;

call s1();

2、 调用存储过程s1

3、创建存储过程s2,实现输入员工姓名后返回员工的家庭住址。

\d @

create procedure s2(in sname char(20) ,out saddress char(200))

begin 

select address into saddress from emp where emp.emp_name = sname;

end @

\d ;

4、调用存储过程s2

call s2('王大光',@www);

select @www;

5、创建一个存储过程avg_sai,有3个参数,分别是dept,gender,接收平均工资,功能查询emp表dept

\d @

create procedure avg_sai(in a_dept int, in a_gender char(4),out  avg_salary decimal(10,2)

begin

select avg(salary) into avg_salary from emp

where dept=a_dept and gender=a_gender;

end @

6、调用存储过程avg sai

call avg_sai (1,'男',@avg_salary)

select avg_salary;

7、删除以上存储过程

drop procedure   avg_sai;

drop procedure   s1;

drop procedure       s2;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/52393.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

排序1

一、概述 直接插入排序 是稳定排序 二、插入排序 1)直接插入排序 2)折半插入排序 3)希尔排序 、 三、交换排序 1)冒泡排序 2)快速排序

Redis计数器:数字的秘密

文章目录 Redis计数器incr 指令用户计数统计用户统计信息查询缓存一致性 小结 技术派项目源码地址 : Gitee :技术派 - https://gitee.com/itwanger/paicodingGithub :技术派 - https://github.com/itwanger/paicoding 用户的相关统计信息 文章数,文章总阅读数&am…

绿洲乐队重组?加拉格尔兄弟重组音乐会的猜测越来越多

据报道,这支英国传奇摇滚乐队计划于 2025 年夏天在曼彻斯特和伦敦举办一系列大型演出。 加拉格尔兄弟终于和解了吗?越来越多的猜测认为,利亚姆和诺埃尔已经放下他们之间的传奇分歧,重新组建绿洲乐队,并举办一场必定是几…

6.Linux_服务器搭建

TFTP服务器 1、概述 什么是TFTP服务器: TFTP(Trivial File Transfer Protocol)即简单文件传输协议是TCP/IP协议族中的一个用来在客户机与服务器之间进行简单文件传输的协议,提供不复杂、开销不大的文件传输服务。端口号为69 介…

编程示例:汉字生成盲文的翻译器

1 翻译器的意义 我国有视障人士2000多万人,需要把大量的文章与书籍转换成盲文书。 2 翻译器的开发原理 根据汉语与盲文符号的对照表,以此为基础,进行汉字与盲文之间的转换。 如下的两个图片是汉语与盲文符号的对照表。 3 翻译器的开发示例…

【计算机网络】mini HTTP服务器框架与代码

注注注:本篇博文都是代码实现细节,但不会进行演示,演示看孪生篇 另外,由于tcp套接字部分本质都是套路,所以就不再进行赘述。 目录 1 请求反序列化2 读取url文件内容3 构建响应 1 请求反序列化 我们肯定会先收到请求&…

HandBrakeCLI 压缩工具的简单实用

HandBrakeCLI -i input.mp4 -o output.mp4 --encoder qsv_h264 -b 500k --preset "Android 576p25" --width 320 --height 576 --quiet--encoder qsv_h264 意思代表inter的gpu编码 -b 500k 设置比特率 --preset "Android 576p25" 设置预设 --width 320 --…

MySQL索引失效的场景

创建一个名为test_db的数据库,并在其中创建一个名为test_table的表。该表包含多个字段,并在某些字段上创建索引。 CREATE DATABASE IF NOT EXISTS test_db;USE test_db;CREATE TABLE IF NOT EXISTS test_table (id INT PRIMARY KEY AUTO_INCREMENT,name…

什么样的条件才会造就这样疯狂的末日期权?

今天带你了解什么样的条件才会造就这样疯狂的末日期权?末日期权一般是指期权合约快到期的一周或者最后三天,当然最后一天就是末日期权的疯狂。 末日期权是指那些接近到期日的期权。 由于剩余时间较短,这些期权的时间价值通常非常低&#xf…

一文吃透SpringMVC

一、SpringMVC简介 1、什么是MVC MVC是一种软件架构模式(是一种软件架构设计思想,不止Java开发中用到,其它语言也需要用到),它将应用分为三块: M:Model(模型)&#xf…

【北京迅为】《i.MX8MM嵌入式Linux开发指南》-第六篇 嵌入式GUI开发篇-第八十五章 Qt控制硬件

i.MX8MM处理器采用了先进的14LPCFinFET工艺,提供更快的速度和更高的电源效率;四核Cortex-A53,单核Cortex-M4,多达五个内核 ,主频高达1.8GHz,2G DDR4内存、8G EMMC存储。千兆工业级以太网、MIPI-DSI、USB HOST、WIFI/BT…

青龙面板本地部署流程结合内网穿透使用手机远程本地服务器薅羊毛

文章目录 前言一、前期准备本教程环境为:Centos7,可以跑Docker的系统都可以使用。本教程使用Docker部署青龙,如何安装Docker详见: 二、安装青龙面板三、映射本地部署的青龙面板至公网四、使用固定公网地址访问本地部署的青龙面板 …

案例分享—优秀ui设计作品赏析

多浏览国外优秀UI设计作品,深入分析其设计元素、色彩搭配、布局结构和交互方式,以理解其背后的设计理念和趋势。 在理解的基础上,尝试将国外设计风格中的精髓融入自己的设计中,同时结合国内用户的审美和使用习惯,进行创…

Datawhale AI 夏令营 第五期 CV Task1

活动简介 活动链接:Datawhale AI 夏令营(第五期) 以及CV里面的本次任务说明:Task 1 从零上手CV竞赛 链接里的教程非常详细,很适合小白上手,从报名赛事到使用服务器平台再到跑模型,手把手教&…

柔版印刷版市场前景:预计2030年全球市场规模将达到20.9亿美元

一、当前市场状况 目前,柔版印刷版市场呈现出较为稳定的发展态势。随着全球经济的逐步复苏,包装印刷等领域对柔版印刷版的需求持续增长。柔版印刷版具有环保、高效、印刷质量高等特点,在食品包装、标签印刷等行业中得到广泛应用。 全球前四…

网上商城|基于SprinBoot+vue的分布式架构网上商城系统(源码+数据库+文档)

分布式架构网上商城系统 目录 基于SprinBootvue的分布式架构网上商城系统 一、前言 二、系统设计 三、系统功能设计 5.1系统功能模块 5.2管理员功能模块 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取: 博主介绍…

时间继电器和定时器

一、概述 1.时间继电器是可以在设定的定时周期内或周期后闭合或断开触点的元器件。 2.时间继电器上可设定的定时周期数量有限,多为一个或两个。定时时长从0.02s至300h(根据产品型号范围不同)。 3.定时器可以理解为一台钟表,它在某个时间点上闭合(断开…

PostgreSQL11 | 事务处理与并发控制

PostgreSQL11 | 事务处理与并发控制 本文章代码已在pgsql11.22版本上运行且通过,展示页由pgAdmin8.4版本提供,本文章第一次采用md文档,效果比csdn官方富文本编辑器好用,以后的文章都将采用md文档 事务管理简介 事物是pgsql中的…

三种相机模型总结(针孔、鱼眼、全景)

相机标定 文章目录 相机标定前言 前言 我们最常见的投影模型Perspective Projection Model描述的就是针孔相机的成像原理。从上面的图根据相似三角形可以得出 参考链接 https://zhuanlan.zhihu.com/p/540969207 相机标定之张正友标定法数学原理详解(含python源码&a…

上线eleme项目

(一)搭建主从从数据库 主服务器master 首先下载mysql57安装包,然后解压 复制改目录到/usr/local底下并且改个名字 cp -r mysql-5.7.44-linux-glibc2.12-x86_64 /usr/local/mysql 删掉/etc/my.cnf 这个会影响mysql57的启动 rm -rf /etc…