期末速成数据库极简版【创建】(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 --先删除外键约束

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

相关推荐
niechel14 分钟前
02-GBase 8s 事务型数据库 客户端工具dbaccess
数据库
扫地生大鹏22 分钟前
Mysql-OCP PPT课程讲解并翻译
数据库
掘金-我是哪吒30 分钟前
分布式微服务系统架构第126集:集群,数据库扩展,多节点分布,分库,分表,分片,分表,运维
运维·数据库·分布式·微服务·系统架构
wangbing112544 分钟前
window server 2012安装sql server2008 r2
数据库
码上飞扬1 小时前
深入解析MySQL联合查询(UNION):案例与实战技巧
数据库·mysql
Leo.yuan1 小时前
数据分析怎么做?高效的数据分析方法有哪些?
大数据·数据库·信息可视化·数据挖掘·数据分析
zm1 小时前
网络编程epoll和udp
服务器·网络·数据库
野犬寒鸦1 小时前
Linux常用命令详解(下):打包压缩、文本编辑与查找命令
linux·运维·服务器·数据库·后端·github
Ultipa2 小时前
回答 | 图形数据库neo4j社区版可以应用小型企业嘛?
数据库·neo4j·图数据库
charlie1145141913 小时前
逐步理解Qt信号与槽机制
数据库·qt