关于索引和约束作业

news/2024/11/20 11:43:49/

作业如下:

学生表:Student (Sno, Sname, Ssex , Sage, Sdept)
学号,姓名,性别,年龄,所在系 Sno为主键
课程表:Course (Cno, Cname,)
课程号,课程名 Cno为主键
学生选课表:SC (Sno, Cno, Score)
学号,课程号,成绩 Sno,Cno为主键

1.用SQL语句创建学生表student,定义主键,姓名不能重名,性别只能输入男或女,所在系的默认值是 “计算机”。
2.修改student 表中年龄(age)字段属性,数据类型由int 改变为smallint。
3.为SC表建立按学号(sno)和课程号(cno)组合的升序的主键索引,索引名为SC_INDEX 。
4.创建一视图 stu_info,查询全体学生的姓名,性别,课程名,成绩。

注意:中文不能用作创建表时别名

Create table Student(
    Sno varchar(100),
    Sname varchar(100),
    Ssex varchar(20),
    Sage int,
    Sdept VARCHAR(100)
)ENGINE=INNODB charset=utf8;
ALTER TABLE Student ADD CONSTRAINT PK_Sno PRIMARY KEY(Sno);
ALTER TABLE Student ADD CONSTRAINT UNIQUE(Sname);

# 注意检查约束在8.0之前,MySQL默认但不会强制的遵循check约束(写不报错,但是不生效,需要通触发器完成)
ALTER TABLE Student ADD CONSTRAINT CHECK(Ssex in('男','女'));

#注意写默认值时不要用"="符号或者直接小括号里面填写值
ALTER TABLE Student CHANGE Sdept Sdept VARCHAR(100) DEFAULT '计算机';

#在改变此字段类型时必须将表字符集改为utf-8
ALTER TABLE Student MODIFY Sage SMALLINT;
CREATE TABLE Course(
Cno INT PRIMARY KEY,
Cname VARCHAR(100)
)ENGINE=INNODB CHARSET=utf8;
CREATE TABLE Sc(
Sno INT PRIMARY KEY,
Cno INT,
Score INT
)ENGINE=INNODB CHARSET=utf8;

#主键索引此处用primary key会报错,但是我理解主键是唯一的,所以用了唯一索引代替
create UNIQUE index SC_INDEX on Sc(Sno ASC,Cno ASC);

#VIEW后面跟值是不能是中文,英文必须是后面select后面的值
CREATE VIEW stu_info AS SELECT Sname,Ssex,Cname,Score FROM Student,Sc,Course WHERE Student.Sno=sc.Sno AND Course.Cno=Sc.Cno;


http://www.ppmy.cn/news/37699.html

相关文章

ChatGPT让现在的软件都土掉渣了

我们家有两个娃,每次我们想要出去时订个酒店时都好麻烦。我在某程上找,我先看有没有家庭房,但家庭房很少,而且有些家庭房实际上只能睡得下两大一小。普通房间能不能睡得下四个人,那可是得查看很多信息,如床…

JavaScript之事件对象的深入

目录一、添加事件监听(addEventListener())二、移除事件监听(removeEventListener())三、键盘事件四、事件委托/代理/委派(srcElement||target)一、添加事件监听(addEventListener()) addEventListener()是…

Python 自动化指南(繁琐工作自动化)第二版:附录 A:安装第三方模块

原文:https://automateboringuff.com/2e/appendix/ 出版后添加:你可以通过安装带有 PIP 的automateboringstuff模块来安装所有需要的模块(带有本书中使用的版本)。从命令提示符或终端窗口运行pip install --user automateboringst…

Redis分布式锁、Redisson原理

文章目录简单的分布式锁实现流程Lua脚本介绍Redisson实现分布式锁原理基本使用原理首先是lock加锁逻辑锁续命逻辑自旋重试逻辑释放锁唤醒其他阻塞线程逻辑RedLock红锁介绍与基本使用问题分布式锁性能提升简单的分布式锁实现流程 最初的版本,使用setnx命令加锁&…

Visual Semantic Role Labeling 文章理解速递

Visual Semantic Role Labeling,CS,2015 论文链接 摘要 1)动机:经典的动作识别方法要么研究在图像或视频剪辑水平上的动作分类任务,要么最多是在做动作的人周围产生一个边界框。这样的输出对图像完全理解是不够的。…

IOC和AOP以及spring框架

众所周知,Spring拥有两大特性:IOC和AOP。IOC,英文全称Inversion of Control,意为控制反转。AOP,英文全称Aspect-Oriented Programming,意为面向切面编程。 Spring核心容器的主要组件是Bean工厂&#xff08…

第12章_MySQL数据类型精讲

第12章_MySQL数据类型精讲 🏠个人主页:shark-Gao 🧑个人简介:大家好,我是shark-Gao,一个想要与大家共同进步的男人😉😉 🎉目前状况:23届毕业生&#xff0c…

【ABP Vnext】实现业务接口的CRUD的操作流程

根据上章:【abp Vnext】下载并运行abp Vnext项目详细教程文档 该实例项目已上传到Gitee:https://gitee.com/henrryhu/acme.-book-store 接下来,演示 建实体、 建DTO、 设置DTO与实体互转映射、 为实体添加DbSet属性、 申明对外开放的接口、 …