期末速成数据库极简版【创建】(1)

目录

前言

【1】T-SQL语句创建数据库

【2】T-SQL语句删除数据库

【3】T-SQL语句创建表

完整性约束

数据类型

例子

【4】T-SQL语句修改表

【5】T-SQL语句删除表


关于数据库,在我们学习Linux网络编程后面会详细学习到,为了应付期末考试,速成下。

  • 语法
  • 例子
  • 全部都是用英文(包括标点符号)
  • 英文大小写无论

前言

数据库有很多模型,例如层次模型,网状模型,关系模型。我们学习数据库,主要是使用数据库的关系模型。

【1】T-SQL语句创建数据库

除了用我们的图形化界面SSMS来创建数据库,考试中考察的使用T-SQL语句来创建数据库。

  • 定义数据库名字
  • 定义数据文件
  • 定义日志文件
  • 关键字create database

复制代码
/*
使用SQL语句
*/
create database mydb
on Primary --定义数据文件
(
name=mydb_data1,
filename='d:\db\mydb_data1.mdf',
size=6mb,
maxsize=30mb,
filegrowth=2mb
),
(
name=mydb_data2,
filename='d:\db\mydb_data2.mdf',
size=2mb,
maxsize=20mb,
filegrowth=10%
)
log on--定义事务日志文件
(
name=mydb_log,
filename='d:\db\mydb_log.ldf',
size=3mb,
maxsize=20mb,
filegrowth=10%
)

怎样去修改数据库名字呢?

复制代码
--修改数据库库名
EXEC sp_renamedb 'student','student1'

【2】T-SQL语句删除数据库

  • 关键字drop database
复制代码
--删除数据库
drop database examlast

【3】T-SQL语句创建表

除了SSMS可以创建表,考试考察T-SQL语句创建表。

关键字create table

完整性约束

数据类型

例子

复制代码
/*
创建Student表
字段名称        数据类型       约束        字段说明
StudentID       char(12)       主键        学生编号
StudentName     char(8)        非空        学生名称
sex             char(2)    非空,男或女    学生性别
Birth           datetime       非空        出生日期
HomeAddr        varchar(80)     --         家庭住址
EntranceTime    datetime      默认值       入学时间
ClassID         char(8)        外键        班级编号
*/
USE Student
Go
create table Student(
StudentID char(12) primary key, 
StudentName char(8) not null,
sex char(2) not null check(sex='男' or sex='女') default '男',
Birth datetime not null,
HomeAddr varchar(80),
EntranceTime datetime default getdate(),  --默认值为当前系统时间
ClassID char(8) references Class(ClassID)
)
Go

【4】T-SQL语句修改表

  • 关键字alter table

复制代码
--1、添加字段
--对表Class添加名为x,数据类型为int的字段
alter table Class add x int

--2、删除字段
--对表Class删除名为x的字段
alter table Class drop column x 

--3、修改字段的定义
--对表Class修改字段ClassName的数据类型为char(30)
alter table Class alter column ClassName char(30)

--4、添加约束
--对表Class的字段ClassName添加唯一性约束
alter table Class add UNIQUE(ClassName)

【5】T-SQL语句删除表

  • 关键字drop table

复制代码
/*
删除表。
PK开头的表示主键约束
FK开头的表示外键约束
CK开头的表示check约束
*/

alter table class 
drop CONSTRAINT FK__Class__Departmen__1FCDBCEB --先删除外键约束

感谢大家,有补充可以在评论区留言!当然因为我们学校期末考试很水,所以以上这些足够应付期末考试,希望大家可以结合自己的情况好好复习!!

相关推荐
九皇叔叔4 分钟前
MySQL数据库 意向锁(初篇)
数据库·mysql
阿拉伯柠檬5 分钟前
MySQL基本查询
linux·数据库·mysql·面试
semantist@语校15 分钟前
第五十七篇|东京银星日本语学校的数据建模:高密度城市中的学习节律、制度边界与 Prompt 接口设计
大数据·数据库·人工智能·学习·百度·prompt·知识图谱
TDengine (老段)24 分钟前
携手桂冠电力、南网储能、中能拾贝,TDengine 三项案例入选“星河奖”
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
阿坤带你走近大数据24 分钟前
Oracle中如何监控SQL执行时间?
数据库·sql·oracle
乘凉~25 分钟前
【Linux作业】CentOS 7下MySQL数据库安装与数据导入实操项目报告
linux·数据库·centos
q行29 分钟前
MySQL学习日志--表之间的关系
数据库·学习·mysql
MoonBit月兔34 分钟前
海外开发者实践分享:用 MoonBit 开发 SQLC 插件(其三)
java·开发语言·数据库·redis·rust·编程·moonbit
电商API_180079052471 小时前
进阶篇:电商商品评论情感分析 + 关键词挖掘(Python NLP 实战)
大数据·开发语言·网络·数据库·人工智能
麦麦鸡腿堡1 小时前
MySQL_INSERT UPDATE DELETE语句
数据库·mysql