【Mysql作业】

第一次作业

要求

1.首先打开Windows PowerShell

2.连接到MYSQL服务器

3.执行以下SQL语句:

-- 创建数据库

CREATE DATABASE mydb6_product;

-- 使用数据库

USE mydb6_product;

-- 创建employees表

CREATE TABLE employees (

id INT PRIMARY KEY,

name VARCHAR(50) NOT NULL,

age INT,

gender VARCHAR(10) NOT NULL DEFAULT 'unknown',

salary FLOAT

);

-- 创建orders表

CREATE TABLE orders (

id INT PRIMARY KEY,

name VARCHAR(100) NOT NULL,

price FLOAT,

quantity INT,

category VARCHAR(50)

);

-- 创建invoices表

CREATE TABLE invoices (

number INT PRIMARY KEY AUTO_INCREMENT,

order_id INT,

in_date DATE,

total_amount FLOAT CHECK (total_amount > 0),

FOREIGN KEY (order_id) REFERENCES orders(id)

);

4.运行结果图

总结

-创建数据库和表:使用 `CREATE DATABASE` 和 `CREATE TABLE`。

  • 验证数据库:`SHOW DATABASES LIKE 'mydb6_product'`。

  • 验证表:`SHOW TABLES` 查看所有表,`SHOW CREATE TABLE 表名` 查看表结构。

第二次作业

要求

1.建库建表

-- 创建数据库

CREATE DATABASE IF NOT EXISTS mydb8_worker;

-- 使用数据库

USE mydb8_worker;

-- 创建表

CREATE TABLE IF NOT EXISTS t_worker (

department_id INT(11) NOT NULL COMMENT '部门号',

worker_id INT(11) PRIMARY KEY NOT NULL COMMENT '职工号',

worker_date DATE NOT NULL COMMENT '工作时间',

wages FLOAT(8,2) NOT NULL COMMENT '工资',

politics VARCHAR(10) NOT NULL DEFAULT '群众' COMMENT '政治面貌',

name VARCHAR(20) NOT NULL COMMENT '姓名',

birth_date DATE NOT NULL COMMENT '出生日期'

);

2.插入数据

INSERT INTO t_worker VALUES (101,1001,'2015-5-4',7500.00,'群众','张春燕','1990-7-1');

INSERT INTO t_worker VALUES (101,1002,'2019-2-6',5200.00,'团员','李名博','1997-2-8');

INSERT INTO t_worker VALUES (102,1003,'2008-1-4',10500.00,'党员','王博涵','1983-6-8');

INSERT INTO t_worker VALUES (102,1004,'2016-10-10',5500.00,'群众','赵小军','1994-9-5');

INSERT INTO t_worker VALUES (102,1005,'2014-4-1',8800.00,'党员','钱有财','1992-12-30');

INSERT INTO t_worker VALUES (103,1006,'2019-5-5',5500.00,'党员','孙菲菲','1996-9-2');

3.完成查询

-- (1) 显示所有职工的基本信息

SELECT * FROM t_worker;

-- (2) 查询所有职工所属部门的部门号,不显示重复的部门号

SELECT DISTINCT department_id FROM t_worker;

-- (3) 求出所有职工的人数

SELECT COUNT(*) AS 职工总数 FROM t_worker;

-- (4) 列出最高工资和最低工资

SELECT MAX(wages) AS 最高工资, MIN(wages) AS 最低工资 FROM t_worker;

-- (5) 列出职工的平均工资和总工资

SELECT AVG(wages) AS 平均工资, SUM(wages) AS 总工资 FROM t_worker;

-- (6) 创建一个只有职工号、姓名和参加工作的新表,名为工作日期表

CREATE TABLE IF NOT EXISTS 工作日期表 AS

SELECT worker_id AS 职工号, name AS 姓名, worker_date AS 参加工作时间

FROM t_worker;

-- (8) 列出工资在4000---8000之间的所有职工姓名

SELECT name AS 姓名 FROM t_worker WHERE wages BETWEEN 4000 AND 8000;

-- (9) 列出所有姓张和孙的职工姓名

SELECT name AS 姓名 FROM t_worker WHERE name LIKE '张%' OR name LIKE '孙%';

-- (10) 列出所有部门号为102和103且不是党员的职工号、姓名

SELECT worker_id AS 职工号, name AS 姓名

FROM t_worker

WHERE department_id IN (102, 103) AND politics != '党员';

-- (13) 求出各部门党员的人数

SELECT department_id, COUNT(*) AS party_member_count

FROM t_worker

WHERE politics = '党员'

GROUP BY department_id;

-- (15) 列出人数大于等于3的部门号和总人数

SELECT department_id, COUNT(*) AS dept_total

FROM t_worker

GROUP BY department_id

HAVING dept_total >= 3;

相关推荐
老邓计算机毕设3 分钟前
SSM智慧社区家政服务系统80q7o(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架
松涛和鸣1 小时前
72、IMX6ULL驱动实战:设备树(DTS/DTB)+ GPIO子系统+Platform总线
linux·服务器·arm开发·数据库·单片机
likangbinlxa1 小时前
【Oracle11g SQL详解】UPDATE 和 DELETE 操作的正确使用
数据库·sql
r i c k2 小时前
数据库系统学习笔记
数据库·笔记·学习
野犬寒鸦2 小时前
从零起步学习JVM || 第一章:类加载器与双亲委派机制模型详解
java·jvm·数据库·后端·学习
IvorySQL3 小时前
PostgreSQL 分区表的 ALTER TABLE 语句执行机制解析
数据库·postgresql·开源
·云扬·3 小时前
MySQL 8.0 Redo Log 归档与禁用实战指南
android·数据库·mysql
IT邦德3 小时前
Oracle 26ai DataGuard 搭建(RAC到单机)
数据库·oracle
惊讶的猫3 小时前
redis分片集群
数据库·redis·缓存·分片集群·海量数据存储·高并发写
不爱缺氧i4 小时前
完全卸载MariaDB
数据库·mariadb