MySQL数据库实验九 MySQL应用系统开发

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL DuckDB 分析主实例,集群系列 8核16GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: MySQL数据库实验九 MySQL应用系统开发

一、实验项目:

使用MySQL进行应用系统开发。

二、实验目的

使学生具备使用MySQL技术进行应用系统开发的能力。

三、实验内容

(一):

1、员工管理系统的业务逻辑如下:

实体“员工”的属性有员工编号、姓名、学历、出生日期、性别、工作年限、地址、电话和所属部门。

实体“部门”的属性有部门编号、名称、备注。

实体“员工薪水”的属性有员工编号、收入、支出。

2、创建员工管理数据库yggl。

1. create database yggl;
2. Show databases;

3、在员工管理数据库yggl中创建员工信息表employees、部门信息表departments和员工薪水情况表salary。

1. use yggl;
2. CREATE TABLE departments (
3. deptid char(3) NOT NULL,
4. deptname char(20) NOT NULL,
5. memo text,
6. PRIMARY KEY  (deptid));
7. 
8. CREATE TABLE employees (
9. empid char(6) NOT NULL,
10. empname char(10) NOT NULL,
11. edu char(4) NOT NULL,
12. birth date NOT NULL,
13. sex char(2) NOT NULL,
14. jobyear tinyint,
15. address varchar(20),
16. phone char(12),
17. deptid char(3) NOT NULL,
18. PRIMARY KEY  (empid),
19. foreign key(deptid)
20. references departments(deptid));
21. 
22. CREATE TABLE salary (
23. empid char(6) NOT NULL,
24. inmoney float(8,2) NOT NULL,
25. outmoney float(8,2) NOT NULL,
26. PRIMARY KEY(empid),
27. foreign key(empid)
28. references employees(empid));
29. show tables;

4、对员工管理数据库yggl创建视图emp_view1,包含所有男员工的员工号码、姓名、工作年限和学历。

1. create or replace view emp_view1(员工编号,姓名,工作年限,学历) as
2. select empid,empname,jobyear,edu from employees
3. where sex='男';
4. select * from emp_view1;

5、对employees表中的部门编号列创建普通索引depart_ind。

1. create index depart_ind on employees(deptid);
2. Show index from employees\G

6、创建存储过程,比较两个员工的实际收入,如前者比后者高就输出0,否则输出1,并调用该存储过程比较000001和010008两个员工的收入。

1. delimiter $$
2. create procedure cp(in id1 char(6),in id2 char(6),out bj int)
3. begin
4. declare sr1,sr2 float(8,2);
5. select inmoney-outmoney into sr1 from salary where empid=id1;
6. select  inmoney-outmoney into sr2 from salary where empid=id2;
7. if sr1> sr2 then set bj=0;
8. else set bj=1;
9. end if;
10. end $$
11. delimiter ;
12. call cp('000001','010008',@bj);
13. select @bj;

(二):

1、创建一个存储函数em_num,返回员工的总人数。

1. delimiter $$
2. create function em_num() returns integer
3. begin
4. return ( select count( * ) from employees);
5. end $$
6. delimiter ;
7. select em_num();

2、创建触发器,在employees表中删除员工信息的同时将salary表中与该员工相关的数据全部删除。

1. DELIMITER $$
2. CREATE TRIGGER EM_DELETE AFTER DELETE
3. ON Employees FOR EACH ROW
4. BEGIN
5. DELETE FROM salary WHERE empid=OLD.empid;
6. END$$
7. DELIMITER ;
8. delete from employees where empid='000001';

3、创建事件,在该事件中创建表temp用来保存员工的总人数,每年统计一次,从现在开始。

1. set @@global.event_scheduler=true;
2. create table temp(counts int not null primary key);
3. create event tjemp  on schedule  every 1 year starts now()
4. do insert into temp select count(*) from employees;
5. select * from temp;

4、创建数据库用户user1,密码为1234。

1. create user user1@localhost identified by '1234';
2. select user from mysql.user;

5、授予用户user1对yggl库中employees表的select操作权限。

1. grant select on yggl.employees to user1@localhost;
2. Show grants for user1@localhost;

6、收回用户user1对yggl库中employees表的select操作权限。

1. revoke select on yggl.employees from user1@localhost;
2. Show grants for user1@localhost;

7、备份yggl数据库中departments表的数据到D盘。要求字段值如果是字符就用双引号标注,字段值之间用逗号隔开,每行以“?”为结束标志。

1. SELECT * FROM  departments INTO OUTFILE 'D:/myfile.txt'
2. FIELDS  TERMINATED BY ','
3. OPTIONALLY ENCLOSED BY '"'
4. LINES TERMINATED BY '?';

8、将上题中的备份文件数据导入bk_depart表中。

1. CREATE TABLE bk_depart LIKE departments;
2. LOAD DATA INFILE  'D:/myfile.txt' INTO TABLE bk_depart
3. FIELDS  TERMINATED BY ','
4. OPTIONALLY ENCLOSED BY '"'
5. LINES TERMINATED BY '?';
6. Select * from bk_depart;
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
2月前
|
存储 人工智能 NoSQL
AI大模型应用实践 八:如何通过RAG数据库实现大模型的私有化定制与优化
RAG技术通过融合外部知识库与大模型,实现知识动态更新与私有化定制,解决大模型知识固化、幻觉及数据安全难题。本文详解RAG原理、数据库选型(向量库、图库、知识图谱、混合架构)及应用场景,助力企业高效构建安全、可解释的智能系统。
|
3月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。
|
3月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
|
3月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
3月前
|
SQL 关系型数据库 MySQL
Mysql数据恢复—Mysql数据库delete删除后数据恢复案例
本地服务器,操作系统为windows server。服务器上部署mysql单实例,innodb引擎,独立表空间。未进行数据库备份,未开启binlog。 人为误操作使用Delete命令删除数据时未添加where子句,导致全表数据被删除。删除后未对该表进行任何操作。需要恢复误删除的数据。 在本案例中的mysql数据库未进行备份,也未开启binlog日志,无法直接还原数据库。
|
3月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
157 3
|
3月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
4月前
|
存储 运维 关系型数据库
从MySQL到云数据库,数据库迁移真的有必要吗?
本文探讨了企业在业务增长背景下,是否应从 MySQL 迁移至云数据库的决策问题。分析了 MySQL 的优势与瓶颈,对比了云数据库在存储计算分离、自动化运维、多负载支持等方面的优势,并提出判断迁移必要性的五个关键问题及实施路径,帮助企业理性决策并落地迁移方案。
|
3月前
|
Ubuntu 安全 关系型数据库
安装与配置MySQL 8 on Ubuntu,包括权限授予、数据库备份及远程连接指南
以上步骤提供了在Ubuntu上从头开始设置、配置、授权、备份及恢复一个基础但完整的MySQL环境所需知识点。
430 7
|
3月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(上)
最终建议:当前系统是完美的读密集型负载模型,优化重点应放在减少行读取量和提高数据定位效率。通过索引优化、分区策略和内存缓存,预期可降低30%的CPU负载,同时保持100%的缓冲池命中率。建议每百万次查询后刷新统计信息以持续优化
235 6

热门文章

最新文章

推荐镜像

更多