SQL编程——MySQL数据库基本操作

实验平台:mysql5.7,
案例:学生-课程-成绩
实际的数据库设计可能和课本中有出入
E-R如下:
这里写图片描述
代码如下:
一、表设计

#1. 数据库创建
DROP DATABASE IF EXISTS scoredb;
CREATE DATABASE scoredb;
#2. 创建表
#1) 创建新表
USE scoredb;
CREATE TABLE student
(
        student_id SMALLINT UNSIGNED NOT NULL,
        student_name VARCHAR(50) NOT NULL,
        student_sex TINYINT(1) NOT NULL DEFAULT 0,
        student_phone VARCHAR(50) DEFAULT NULL,
        student_addr_id SMALLINT UNSIGNED NOT NULL,
        PRIMARY KEY (student_id)
) ENGINE=INNODB DEFAULT CHARSET=utf8;
#2) 根据已有的表创建新表
USE scoredb;
-1. CREATE TABLE student like student_info;
-2. CREATE TABLE student AS SELECT student_info.student_id,
    student_info.student_name, student_info.student_sex,
    student_info.student_phone, student_info.student_addr_id
    FROM student_info;
#3. 删除表
USE scoredb;
DROP TABLE student_info;
#4 修改表
USE scoredb;
ALTER TABLE student ADD COLUMN depart_id SMALLINT UNSIGNED NOT NULL;
ALTER TABLE student ADD PRIMARY KEY(student_id);
ALTER TABLE student DROP PRIMARY KEY(student_id);
#5 创建其他相关表
USE scoredb;
CREATE TABLE address
(
    addr_id SMALLINT UNSIGNED NOT NULL,
    addr_info VARCHAR(100) NOT NULL,
    PRIMARY KEY(addr_id)
) ENGINE=INNODB,CHARSET=utf8;
create TABLE department
(
    depart_id SMALLINT UNSIGNED NOT NULL,
    depart_name VARCHAR(100) NOT NULL,
    PRIMARY key(depart_id)
) ENGINE=INNODB,CHARSET=utf8;
create 
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Sakila是MySQL官方提供的一个样例数据库,用于演示和练习MySQL数据库的使用。数据库包含了一个虚构的DVD租赁店的数据,其中包括客户、电影、租赁记录等等。 Sakila数据库包含16张表,包括: 1. `actor`:演员表,包含演员的ID、名字和最后更新时间。 2. `address`:地址表,包含地址的ID、地址、邮编、电话和最后更新时间。 3. `category`:电影类别表,包含类别的ID和名称以及最后更新时间。 4. `city`:城市表,包含城市的ID、城市名称、国家ID和最后更新时间。 5. `country`:国家表,包含国家的ID、国家名称和最后更新时间。 6. `customer`:客户表,包含客户的ID、姓名、地址、邮编、电话、积分、注释和最后更新时间。 7. `film`:电影表,包含电影的ID、标题、描述、发行年份、语言ID、原始语言ID、租金、长度、评级和最后更新时间。 8. `film_actor`:电影演员表,包含电影ID和演员ID。 9. `film_category`:电影类别表,包含电影ID和类别ID。 10. `inventory`:库存表,包含DVD的ID、电影ID和最后更新时间。 11. `language`:语言表,包含语言的ID、名称和最后更新时间。 12. `payment`:支付表,包含支付的ID、客户ID、租赁ID、支付时间、租赁时长和支付金额。 13. `rental`:租赁表,包含租赁的ID、客户ID、电影ID、租赁时间和最后更新时间。 14. `staff`:员工表,包含员工的ID、姓名、地址、邮编、电话、邮箱、店铺ID、用户名、密码和最后更新时间。 15. `store`:店铺表,包含店铺的ID、地址、邮编、电话和最后更新时间。 16. `sales_by_film_category`:按电影类别统计销售额的视图,包含类别名称和销售额。 使用Sakila数据库可以练习SQL查询、联结、聚合、子查询等等操作,是学习MySQL的很好的工具。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值