SQL分类
DDL data definition language
create alter drop
DML data manipulation language
insert update delete select
DCL data control language
grant revoke deny
数据库的创建和管理
文件 数据文件(主数据文件.mdf 辅助数据文件.ndf)
日志文件 .ldf
文件组 逻辑结构 包含数据文件
创建数据库
create database 数据库名
on primary
(name=,filename=,size=,maxsize=,filegrowth=),
filegroup 文件组名
(name=,filename=,size=,maxsize=,filegrowth=)
log on
(name=,filename=,size=,maxsize=,filegrowth=),
(name=,filename=,size=,maxsize=,filegrowth=)
修改
alter database 数据库名
|add filegroup 文件组名
|add file() to filegroup 文件组名
|add log file()
|modify name=新数据库名
|modify file(name=,newname=,size=,maxsize=,filegrowth=)
|modify filegroup 文件组名 default
|remove file
|set 数据库选项
删除
drop database 数据库名
数据库收缩
dbcc shrinkfile
dbcc shrinkdatabase
数据库信息查看
sp_helpdb
dbcc sqlperf
sp_spaceused
dbcc checkdb
系统数据类型
整型:bigint int smallint tinyint
精确数值:decimal(p,s) numeric(p,s)
近似数值:float real
货币:money smallmoney
日期:datetime smalldatetime
--SQL2008
date time datetime2 datetimeoffset
字符:char(n) varchar(n) varchar(max)
nchar(n) nvarchar(n) nvarchar(max)
bit uniqueidentifier table
......
表的创建
create table 表名
(列名 数据类型,
列名 数据类型 not null,
列名 数据类型 identity(seed,increment))
表的修改
alter table 表名
|add 列名 数据类型 属性
|alter column 列名 新数据类型|旧数据类型 属性
|drop column 列名 数据类型
表的删除
drop table 表名
DML
insert
insert into 表名(列名列表) values(对应值)
注意:字符和日期数据加单引号
insert into 表名(列名列表) select语句
update
update 表名 set 列名=值 where 条件
delete
delete from 表名 where 条件
select
语句 子句
select:结果中的列
*
列名
distinct
top(n) [percent]
+
函数
算术运算符
with ties
列别名
列名 as 列别名
列名 列别名
列别名=列名
into:将查询结果放入新表
from:数据源(具体表名;CTE;derived table)
where:条件 对返回的数据行进行限定
逻辑运算符 and not or
比较运算符 > < >= <= <> != =
算术运算符
between...and...:给定取值范围,包括边界
in(值列表):取给定值
like:字符串的模糊查询
通配符: %:任意长度任意字符
_: 任意单个字符
[]:取给定的任意一个
[^] :除了给定的字符,任意取一个
is null:空值判断
exists:判断存在性
group by:分组汇总+聚合函数
having:对分组后的数据进行筛选
order by:排序
升序asc(默认) 降序 desc
可以按多个列排序 null作为最小值
join:多表连接
where select 列名 from 表1,表2 where 表1.列=表2.列 and 条件
join select 列名 from 表1 *JOIN* 表2 on 表1.列=表2.列 where 条件
内连接:[inner] join 连接字段的值在两张表中相同的数据
左外联结:left [outer] join 连接字段的值在两张表中相同的数据,连接字段的值在左表有在右表没有的数据
右外连接:right [outer] join 连接字段的值在两张表中相同的数据,连接字段的值在右表有在左表没有的数据
全连结:full [outer] join 连接字段的值在两张表中相同的数据,连接字段的值在左表有在右表没有的数据,连接字段的值在右表有在左表没有的数据
stu exam
id name id eid score
1 a 1 2072 100
2 b 2 2072 80
3 c 3 2072 60
4 d null 2072 70
交叉连接
笛卡尔积 m*n
select 列名 from 表1 cross join 表2
自连接
union
行叠加
select语句 *union* select语句
union//union all//intersect//except
子查询--可以转换为多表
select 字段 from 表1 where 字段 in(select语句)
数据完整性
实体完整性:行唯一
域完整性:对字段的取值范围或格式进行限制
引用完整性:维护表之间的数据一致性
实现:规则 默认 约束
约束
主键约束 primary key
一张表只有一个主键约束,可以创建在多个列上,创建主键约束的字段取值唯一,不能为NULL,创建主键约束会自动创建唯一聚集索引
唯一约束 unique
一张表可以有多个唯一约束,可以创建在多个列上,创建唯一约束的字段可以为NULL,取值唯一(包括NULL),创建唯一约束会自动创建唯一非聚集索引
检查约束 check
对字段的取值范围或格式进行限制
默认约束 default
如果某列定义了默认约束,插入数据时,不给值,自动填充默认值
外键约束 foreign key
被参照表的被参照列要定义主键约束或唯一约束,维护表之间的数据一致性
创建表的同时,创建约束************************************
create table 表名
(列名 数据类型,
列名 数据类型 not null,
列名 数据类型 primary key,
列名 数据类型 unique,
列名 数据类型 check(表达式)
列名 数据类型 default 默认值,
列名 数据类型 references 被参照表(被参照列))
表创建成功后添加约束***************************************
primary key(主键字段)
unique(唯一字段)
alter table 表名 add constraint 约束名 check(表达式)
default 默认值 for 列名
foreign key(参照字段) references 被参照表(被参照列)
视图
分类:普通视图 分区视图 索引视图
数据库中只有视图定义,不存放数据
创建视图
create view 视图名
as
select语句
视图选项
create view 视图名
with encryption | schemabinding
as
select语句
with check option
备份还原
备份目标
备份设备:实现创建好,通过命令和图形界面均可查看备份内容
备份文件:创建的同时创建,只能通过命令查看
故障恢复模型
大容量日志:对大批量数据操作只记录结果不记录过程
简单:不能进行日志备份
完整:
备份类型
完整备份
backup database 数据库名 to disk=''
backup database 数据库名 to 备份设备名
差异备份
backup database 数据库名 to disk='' with differential
backup database 数据库名 to 备份设备名 with differential
日志备份
backup log 数据库名 to disk=''
backup log 数据库名 to 备份设备名
文件和文件组备份
backup database 数据库名 file= to disk=''
backup database 数据库名 filegroup= to 备份设备名
尾日志备份
backup log 数据库名 to disk='' with no_truncate
backup log 数据库名 to 备份设备名 with no_truncate