MySQL---视图索引

表定义:

学生表:Student (Sno, Sname, Ssex , Sage, Sdept)

学号,姓名,性别,年龄,所在系 Sno为主键

课程表:Course (Cno, Cname,)

课程号,课程名 Cno为主键

学生选课表:SC (Sno, Cno, Score)

学号,课程号,成绩 Sno,Cno为主键

1.用SQL语句创建学生表student,定义主键,姓名不能重名,性别只能输入男或女,所在系的默认值是 “计算机”。

创建Student表

mysql> create table Student(                                             

    -> Sno int primary key,                                              

    -> Sname varchar(20) unique,                                         

    -> Ssex enum('男','女'),                                             

    -> Sage int,                                                         

    -> Sdept varchar(30) default '计算机'                                

    -> );                                                                

Query OK, 0 rows affected (0.01 sec)

#注意:在MySQL中,你可以使用枚举类型(ENUM)来限制字段的值只能是特定的选项。

Student表插入数据

mysql> insert into Student values(1,'张三','男',20,'计算机');            

mysql> insert intoStudent values(2,'李四','男',23,'英语');                                                          mysql> insert into Student values(3,'王五','女',22,'数学');                                                         mysql> insert into Student values(4,'小明','女',18,'数学');                                                

mysql> insert into Student values(5,'哈利姆','男',19,'计算机');          

#查看表结构

mysql> desc Student;

#查看Student表数据

mysql> select * from Student;

2.修改student 表中年龄(age)字段属性,数据类型由int 改变为smallint。

#在MySQL中,alter table 语句可以用于修改表的结构,包括添加、删除或修改列,以及重命名表。其中, modify关键字可以用于修改现有列的定义

mysql> alter table Student modify Sage smallint;

3.为SC表建立按学号(sno)和课程号(cno)组合的升序的主键索引,索引名为SC_INDEX 。

#创建学生选课表SC

mysql> create table SC(                                                  

    -> Sno int,                                                          

    -> Cno int,                                                          

    -> Score int,                                                        

    -> primary key (Sno,Cno)                                             

    -> );                                                                

Query OK, 0 rows affected (0.01 sec)

#学生选课表SC中插入数据

mysql> insert into SC values(1,1,90);                                    

mysql> insert into SC values(2,2,80);                                    

mysql> insert into SC values(3,3,85);                                    

mysql> insert into SC values(4,3,95);                                    

mysql> insert into SC values(5,1,87);                                    

#查询学生选课表SC中的内容

mysql> select * from SC;

#在MySQL中,可以使用 create index 语句来创建索引。在默认情况下,MySQL会对索引进行升序排序。

#创建索引的用法:create index on index_name on  table_name ( column_list );

#在这个格式中,index_name是我们想要创建的索引的名称,table_name 是我们想要在其上创建索引的表的名称,column_list是我们想要索引的列的列表。

mysql> create index SC_INDEX on SC(Sno,Cno);

4.创建一视图 stu_info,查询全体学生的姓名,性别,课程名,成绩。

#创建课程表Course

mysql> create table Course(                                              

    -> Cno int primary key,                                              

    -> Cname varchar(30)                                                 

    -> );                                                                

Query OK, 0 rows affected (0.01 sec)

#课程表Course中插入数据

mysql> insert into Course values(01,'计算机');                           

mysql> insert into Course values(02,'英语');                                                                           mysql> insert into Course values(03,'数学');                             

#查询课程表的数据

mysql> select * from Course;

#在MySQL中,可以使用create view...as 语句来创建视图。视图是一种虚拟表,基于SQL语句的结果集。视图包含行和列,就像真实的表一样。视图中的字段来自数据库中的一个或多个真实表。

mysql> create view v_Stu_SC_C as (select Sname 姓名,Ssex 性别,Cname 课程号,Score 成绩 from Student Stu inner join SC on Stu.Sno=SC.Sno inner join   Course C on SC.Cno=C.Cno);

SQL语句分析:涉及三张表的连接,因为选课表SC中的Sno与学生表Sno数据一致,SC表中的Cno与课程表Cno数据一致,所以选课表SC表当作中间参数,连接另外两张表

mysql> select Sname 姓名,Ssex 性别,Cname 课程号,Score 成绩 from Student Stu inner join SC on Stu.Sno=SC.Sno inner join Course C on SC.Cno=C.Cno;

#描述视图表v_Stu_SC_C的结构

mysql> desc v_Stu_SC_C;

 #查询视图表v_Stu_SC_C中的内容

mysql> select * from v_Stu_SC_C;

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【JavaEE】文件操作 —— IO

文件操作 —— IO 1. 文件的属性 文件内容文件大小文件路径文件名称 2. 文件的管理 采用树形结构进行管理。 3. 文件路径 分为两种:相对、绝对路径。 相对路径:相对于当前位置的路径,以“./xxx.xxx”为标志绝对路径:以从盘符…

MySQL作业

目录 1.实验需求1: (1) (2) (3) (4) (5) 2.实验步骤1: (1)完成上述实验需求1,需要先创建一…

DAY13--learning English

一、积累 1.jog Riding rollercoaster is even like a daily jog for this man, 对这个男人来说坐过山车甚至就像每天散步一样轻松. 2.admission Admission to guilt. 承认有罪 3.summon I love the guy hes literally summon Karpov into material plane. 我喜欢这家伙他真…

牛牛的猜球游戏

置换群 前缀和 思想 学好线性代数 做这题很有意思,记得多校也有一道置换群的好题~ 把多次变换看成一个置换矩阵就好也就是 I (一开始为单位矩阵) ->经过A作用产生了B->经过C作用产生了D 即 CAI D 现在让我们求一下 CI ? 两边右…

C++浮点数比较

根据资料&#xff0c;C浮点数计算时存在精度误差&#xff0c;在一些情况下比较浮点数可能应使用特定的比较函数&#xff1b; #include "stdafx.h" #include<iostream>using namespace std;#define EPS 1e-9int main(int argc, char* argv[]) {double a 0.3;do…

利用appium自动控制移动设备并提取数据

安装appium-python-client模块并启动已安装好的环境 安装appium-python-client模块 在window的虚拟环境下执行pip install appium-python-client 启动夜神模拟器&#xff0c;进入夜神模拟器所在的安装路径的bin目录下&#xff0c;进入cmd终端&#xff0c;使用adb命令建立adb…

Klocwork—符合功能安全要求的自动化静态测试工具

产品概述 Klocwork是Perforce公司产品&#xff0c;主要用于C、C、C#、Java、 python和Kotlin代码的自动化静态分析工作&#xff0c;可以提供编码规则检查、代码质量度量、测试结果管理等功能。Klocwork可以扩展到大多数规模的项目&#xff0c;与大型复杂环境、各种开发工具集成…

在k8s上部署ClickHouse

概述 clickhouse的容器化部署&#xff0c;已经有非常成熟的生态了。在一些互联网大厂也已经得到了大规模的应用。 clickhouse作为一款数据库&#xff0c;其容器化的主要难点在于它是有状态的服务&#xff0c;因此&#xff0c;我们需要配置PVC。 目前业界比较流行的部署方式有…

使用pyechart创建基础柱状图

from pyecharts.charts import Bar# 构建柱状图对象 bar Bar()# 添加X轴数据 bar.add_xaxis(["中国","美国","英国"])# 添加Y轴数据 bar.add_yaxis("GDP",[30,20,10])# 绘图 bar.render("基础柱状图.html")效果演示&#x…

Git学习笔记(第6章):GitHub操作(远程库操作)

目录 6.1 远程库操作 6.1.1 创建远程库 6.1.2 命名远程库 6.1.3 本地库推送到远程库(push) 6.1.4 远程库拉取到本地库(pull) 6.1.5 远程库克隆到本地库(clone) 6.2 团队内协作 6.3 跨团队协作 6.4 SSH免密登录 6.1 远程库操作 命令 作用 git remote -v 查看所有远程…

C语言·预处理详解

1. 预定义符号 C语言设置了一些预定义符号&#xff0c;可以直接使用&#xff0c;预定义符号也是在预处理期间处理的 __FILE__ 进行编译的源文件 __LINE__ 文件当前的行号 __DATE__ 文件被编译的日期 __TIME__ 文件被编译的时间 __STDC__ 如果编译器遵循ANSI C&#xff0c;…

正则表达式..

1.字符串的合法检验 现在有一个字符串验证码 我们需要检验其的合法性 什么条件才能够使得字符串合法呢&#xff1f;就是6-10个字符串长度 并且以字母开头 并且其中由字母、数字、下划线构成 那么我们可以先通过自定义的方式进行检验 public class Main {public static void m…

CodeWave智能开发平台--03--目标:应用创建--10初级采购管理系统总结

摘要 本文是网易数帆CodeWave智能开发平台系列的第14篇&#xff0c;主要介绍了基于CodeWave平台文档的新手入门进行学习&#xff0c;实现一个完整的应用&#xff0c;本文主要完成10初级采购管理系统总结 CodeWave智能开发平台的14次接触 CodeWave参考资源 网易数帆CodeWave…

day3:基于UDP模型的简单文件下载

思维导图 tftp文件下载客户端实现 #include <head.h> #define SER_PORT 69 #define SER_IP "192.168.125.223" int link_file() {int sfdsocket(AF_INET,SOCK_DGRAM,0);if(sfd-1){perror("socket error");return -1;}return sfd; } int filedownloa…

luffy商城项目(一)

企业项目类型 # 1 面向互联网用户&#xff1a;商城类项目 -微信小程序商城 # 2 面向互联网用户&#xff1a;二手交易类的 -咸鱼 -转转 # 3 公司内部项目&#xff1a;python写的重点 -oa系统 -打卡系统工资核算系统 -第三方公司做的&#xff1a…

Vue+ElementUI技巧分享:el-table 中实现灵活的文本换行

文章目录 前言一、使用 CSS 选择器实现换行二、使用 HTML 标签和 CSS 类实现换行三、利用数组实现每项数据单独一行四、动态生成带换行文本的表格五、完整代码演示总结 前言 Element UI 是 Vue.js 的一个流行组件库&#xff0c;广泛应用于构建企业级前端界面。在数据密集型的应…

Go语言基础快速上手

1、Go语言关键字 2、Go数据类型 3、特殊的操作 3.1、iota关键字 Go中没有明确意思上的enum&#xff08;枚举&#xff09;定义&#xff0c;不过可以借用iota标识符实现一组自增常亮值来实现枚举类型。 const (a iota // 0b // 1c 100 // 100d // 100 (与上一…

图像比特级置乱加密的安全性

一、概述 Liu等人[1] 提出一种冗余空间转移&#xff08;简称&#xff1a;RST&#xff09;加密算法。RST加密中&#xff0c;用户首先将图像分解为8个位平面&#xff0c;根据位平面置乱秘钥置乱图像的位平面以改变图像的像素值。接着&#xff0c;将位平面置乱图像分块&#xff0…

【第七在线】利用大数据与AI,智能商品计划的未来已来

随着科技的快速发展&#xff0c;大数据和人工智能(AI)已经成为各行各业变革的重要驱动力。在服装行业&#xff0c;这两大技术的结合正在深刻改变着传统的商品计划方式&#xff0c;引领着智能商品计划的未来。 一、大数据与AI在智能商品计划中的角色 大数据为智能商品计划提供了…

go语言(十)---- 面向对象封装

面向对象的封装 package mainimport "fmt"type Hero struct {Name stringAd intLevel int }func (this Hero) Show(){fmt.Println("Name ", this.Name)fmt.Println("Ad ", this.Ad)fmt.Println("Level ", this.Level)}func (thi…
最新文章