use master
--sysdatabases 存储数据库的相关信息
--exists存在
--判断myt52的数据库是否存在,存在就删除
if exists(select * from sysdatabases where name='myt52')
drop database myT52
--创建一个myt52的数据库
create database myT52
on primary --主数据文件
(
name='myt52',--数据库名
filename='D:\myt52.mdf',--数据文件的位置
size=100mb, --初始值
maxsize=110mb,--数据库达到的最大值
filegrowth=10mb--数据文件每次增长值
)
log on --主日志文件
(
name='myt52_log',--数据库名
filename='D:\myt52.ldf',--数据文件的位置
size=100mb, --初始值
maxsize=110mb,--数据库达到的最大值
filegrowth=10mb--数据文件每次增长值
)
--查询该数据库中所有的用户表
select * from sysobjects where xtype='u'
if exists(select * from sysobjects where name='学生表')
drop table 学生表--删除学生表
create table 学生表(
学号 int primary key,--主键约束(唯一标识出一个实体)
姓名 nvarchar(20), --字符串
性别 bit, --字节(0,1)
头像 image, --文件
生日 datetime, --时间
--check(条件)检查约束
分数 numeric(5,2) check(分数>=0 and 分数<=100),--2位小数位,3位整数
地址 nvarchar(20) not null default('湖南')--默认约束,默认为湖南
)
drop table 考试成绩表
create table 考试成绩表(
标识列 int identity(1,1),--identity(初始值,自增值)
学号 int references 学生表(学号),--外键约束
--references指向 学生表(主表)(主键)
分数 int,
科目 nvarchar(20)
)
char ,varchar--变长字符串(节省空间)
nvarchar--无论是中文还是英文都当成1个字符
use pubs
--将jobs表中所有列的值插入到“新表”(不存在)中
select * into 新表 from jobs
--将jobs表中所需要的列的值插入到“新表”(不存在)中
select job_id,job_desc into 新表 from jobs
drop table 新表
create table 学生表(
学号 int primary key,
姓名 nvarchar(20),
性别 bit,
头像 image,
分数 numeric(5,2),
地址 nvarchar(20)
)
create table 考试成绩表(
标识列 int identity(1,1),
学号 int,
分数 int,
科目 nvarchar(20)
)
--添加检查约束 alter修改 constraint约束
alter table 学生表
add constraint ck_分数 check(分数>=0 and 分数<=100)
--删除检查约束
alter table 学生表
drop constraint ck_分数
--添加默认值约束
alter table 学生表
add constraint df_地址 default('湖南') for 地址
--添加外键约束
alter table 考试成绩表
add constraint fk_学号
foreign key (学号) --考试成绩表的学号
references 学生表(学号) --学生表的学号
--添加列
alter table 学生表
add 生日 datetime
--删除列
alter table 学生表
drop column 生日