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

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

相关推荐
独行soc34 分钟前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍08-基于时间延迟的SQL注入(Time-Based SQL Injection)
数据库·sql·安全·渗透测试·漏洞挖掘
White_Mountain1 小时前
在Ubuntu中配置mysql,并允许外部访问数据库
数据库·mysql·ubuntu
Code apprenticeship1 小时前
怎么利用Redis实现延时队列?
数据库·redis·缓存
百度智能云技术站1 小时前
广告投放系统成本降低 70%+,基于 Redis 容量型数据库 PegaDB 的方案设计和业务实践
数据库·redis·oracle
装不满的克莱因瓶1 小时前
【Redis经典面试题六】Redis的持久化机制是怎样的?
java·数据库·redis·持久化·aof·rdb
梦想平凡3 小时前
PHP 微信棋牌开发全解析:高级教程
android·数据库·oracle
TianyaOAO3 小时前
mysql的事务控制和数据库的备份和恢复
数据库·mysql
Ewen Seong3 小时前
mysql系列5—Innodb的缓存
数据库·mysql·缓存
码农老起4 小时前
企业如何通过TDSQL实现高效数据库迁移与性能优化
数据库·性能优化
夏木~5 小时前
Oracle 中什么情况下 可以使用 EXISTS 替代 IN 提高查询效率
数据库·oracle