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

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

相关推荐
X566127 分钟前
如何在 Laravel 中正确保存嵌套动态表单数据(主服务与子服务)
jvm·数据库·python
虹科网络安全2 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
2301_771717212 小时前
解决mysql报错:1406, Data too long for column
android·数据库·mysql
小江的记录本2 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
dvjr cloi2 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
dFObBIMmai3 小时前
MySQL主从同步中大事务导致的延迟_如何拆分大事务优化同步
jvm·数据库·python
szccyw03 小时前
mysql如何限制特定存储过程执行权限_MySQL存储过程安全访问
jvm·数据库·python
czlczl200209253 小时前
利用“延迟关联”优化 MySQL 巨量数据的深分页查询
数据库·mysql
ACP广源盛139246256734 小时前
IX8024与科学大模型的碰撞@ACP#筑牢科研 AI 算力高速枢纽分享
运维·服务器·网络·数据库·人工智能·嵌入式硬件·电脑
Elastic 中国社区官方博客4 小时前
ES|QL METRICS_INFO 和 TS_INFO:为你的时间序列数据建立目录
大数据·数据库·elasticsearch·搜索引擎·信息可视化·全文检索