为了账号安全,请及时绑定邮箱和手机立即绑定

mysql-数据定义语句

标签:
MySQL

2、创建一个名为test的数据库

create database test;

https://img1.sycdn.imooc.com//5d2d312300011ce404670434.jpg

image.png

4、创建一个名为student的表

 create table student(
     sno char(9) primary key,   //设置sno为主键
     sname char(20) unique,   //设置sname取唯一值
     ssex char(2),
     sage smallint,
     sdept char(20)
     );

 create table course(
     cno char(4) primary key,
     cname char(40) not null,  //设置cname字段不能为空,列级完整性约束条件
     cpno char(4),   //cpno 表示先修课
     ccredit smallint,     //参照表和被参照表可以是同一张表
     foreign key (cpno) references course(cno)   // 表级完整性约束条件,cpno是外码,被参照的表是course,被参照的列是cno 
     );

 create table sc(
     sno char(9),
     cno char(4),
     grade smallint,
     primary key (sno,cno),
     foreign key(sno) references student(sno),
     foreign key(cno) references course(cno)
     );

https://img1.sycdn.imooc.com//5d2d312800013ff004410211.jpg

image.png

6、向student表增加“入学时间”列,其数据类型为日期型

alter table student add s_entrance date;

https://img1.sycdn.imooc.com//5d2d312c000128ef05310105.jpg

image.png

7、将年龄的数据类型改为整型

 alter table student change sage sage int; //第一种修改方式 alter table 表名称 change 字段原名称 字段新名称 字段类型 [是否允许非空]

 alter table student modify sage smallint;  //第二种修改方式

第一种方式可以修改列名


https://img1.sycdn.imooc.com//5d2d314a0001d7e005580116.jpg

image.png


https://img1.sycdn.imooc.com//5d2d314f0001ef6a05250096.jpg

image.png

8、增加课程名称必须取唯一值的约束条件

 alter table course add unique(cname);

https://img1.sycdn.imooc.com//5d2d31520001886804820094.jpg

image.png

9、删除表

 drop table student [restrict]; //默认是restrict删除,即删除是有限制条件的。

在mysql中添加restrict或是cascade,则欲删除的表不能被其他表的约束所引用(如check,foreign key 等约束),不能有视图,不能有触发器,不能有存储过程或函数等。如果存在这些依赖该表的对象,则此表不能被删除。


https://img1.sycdn.imooc.com//5d2d316c0001567907170076.jpg

image.png


https://img1.sycdn.imooc.com//5d2d3173000145d407180068.jpg

image.png


10、建立索引

create unique index stusno on student(sno); //unique 表明此索引的每一个索引值只对应唯一的数据记录create unique index coucno on course(cno); create unique index scno on sc(sno asc, cno desc); //asc 升序排列,desc 降序排列

https://img1.sycdn.imooc.com//5d2d317800012a0d05860094.jpg

image.png


11、删除索引

 alter table student drop index stusno;

https://img1.sycdn.imooc.com//5d2d318b000140de05030123.jpg

image.png


12、修改索引

 alter table sc rename index scno to scsno;

https://img1.sycdn.imooc.com//5d2d318f000158f605530092.jpg

image.png



作者:桓宇Harry
链接:https://www.jianshu.com/p/15ab4bcee425


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消