史上最全的MSSQL复习笔记

1.什么是SQL语句

sql语言:结构化的查询语言。(Structured Query Language),是关系数据库管理系统的标准语言。

它是一种解释语言:写一句执行一句,不需要整体编译执行。
语法特点:
1.没有“ ”,字符串使用‘ ’包含
2.没有逻辑相等,赋值和逻辑相等都是=
3.类型不再是最严格的。任何数据都可以包含在‘ ’以内
4.没有bool值的概念,但是在视图中可以输入true/false
5.它也有关系运算符:> < >= <= = <> != ,它返回一个bool值
6.它也有逻辑运算符: !(not) &&(and) ||(or)
7.它不区别大小写

2.使用sql语句创建数据库和表

语法:
create database 数据库名称
on primary –默认在主文件组上
(
name=’逻辑名称_data’ , –当你发现它不是一句完整的sql语句,而仅仅是一个处理结构中的某一句的时候,就需要添加 ,
size=初始大小,–数值不包含在‘’以内
filegrowth=文件增长 ,
maxsize=最大容量,
filename=’物理路径’
)
log on
(
name=’逻辑名称_log’ , –当你发现它不是一句完整的sql语句,而仅仅是一个处理结构中的某一句的时候,就需要添加 ,
size=初始大小,–数值不包含在‘’以内
filegrowth=文件增长 ,
maxsize=最大容量, –一般来说日志文件不限制最大容量
filename=’物理路径’
)

3.创建数据表

语法:
create table 表名
(
字段名称 字段类型 字段特征(是否为null,默认值 标识列 主键 唯一键 外键 check约束),
字段名称 字段类型 字段特征(是否为null,默认值 标识列 主键 唯一键 外键 check约束)
)
创建老师表Teacher :Id、Name、Gender、Age、Salary、Birthday

4.数据完整性约束

实体完整性:实体就是指一条记录。这种完整性就是为了保证每一条记录不是重复记录。是有意义的
— 主键:非空和唯一.一个表只有一个主键,但是一个主键可以是由多个字段组成的 组合键
— 标识列:系统自动生成,永远不重复
— 唯一键:唯一,但是可以为null,只能null一次

域完整性:域就是指字段,它是为了保证字段的值是准和有效,合理值
— 类型 是否null,默认值,check约束,关系

自定义完整性:
— check约束 , 存储过程 触发器

引用完整性:一个表的某个字段的值是引用自另外一个表的某个字段的值。引用的表就是外键表,被引用的表就是主键表
— 1.建立引用的字段类型必须一致
— 2.建立引用的字段的意义一样
— 3.建立主外键关系的时候选择 外键表 去建立主外键关系
— 4.建立主外键关系的字段在主表中必须是主键或者唯一键
— 5.对于操作的影响 :
— 1.在添加数据时,先添加主键表再添加外键表数据
— 2.在删除的时候先外键表数据再删除主键表数据
— 级联的操作:不建议使用:会破坏数据完整性
— 不执行任何操作:该报错就报错,该删除就删除
— 级联:删除主表记录,从表引用该值的记录也被删除
— 设置null:删除主表记录,从表对应的字段值设置为null,前提是可以为null
— 设置为default:删除主表记录,从表对应的字段值设置为default,前提是可以为default

主键约束(PK Primary key) 唯一键约束(UQ unique) 外键约束(FK foreign key) 默认值约束(DF default) check约束(CK check)

语法:
alter table 表名
add constraint 前缀_约束名称 约束类型 约束说明(字段 关系表达式 值)

5.四中基本字符类型说明

6.SQL基本语句

数据插入
调用方法 一 一对应原则:类型对应,数量对应,顺序对应

语法: 形参 实参
insert into 表名([字段列表]) values(值列表) –数据必须要符合数据完整性
插入操作是单个表的操作
插入操作insert一次只能插入一条记录

数据删除
语法:
delete [from] 表名 where 条件

数据更新(数据修改):一定需要考虑是否有条件

语法:
update 表名 set 字段=值,字段=值 。。where 条件

数据检索–查询

语法: *代表所有字段
select */字段名称列表 from 表列表

7.类型转换函数

8.日期函数

9.数学函数

10.字符串函数

11.联合结果集union

12.CASE函数用法

相当于switch case—c#中的switch…case只能做等值判断
这可以对字段值或者表达式进行判断,返回一个用户自定义的值,它会生成一个新列
2.要求then后面数据的类型一致
1.第一种做等值判断的case..end
case 字段或者表达式
when .值..then .自定义值
when .值..then .自定义值
…..
else 如果不满足上面所有的when就满足这个else
end

13.IF ELSE语法

1,.没有{},使用begin..end.如果后面只有一句,可以不使用begin..end包含
2.没有bool值,只能使用关系运算符表达式
3.也可以嵌套和多重
4.if后面的()可以省略

14.WHILE循环语法

没有{},使用begin..end
没有bool值,需要使用条件表达式
可以嵌套
也可以使用break,continue

15.子查询

子查询–一个查询中包含另外一个查询。被包含的查询就称为子查询,。包含它的查询就称父查询
1.子查询的使用方式:使用()包含子查询
2.子查询分类:

1.独立子查询:子查询可以直接独立运行
查询比“王八”年龄大的学员信息
select * from Student where BornDate<(select BornDate from Student where StudentName=’王八’)
2.相关子查询:子查询使用了父查询中的结果

16.表连接Join

17.事务

一种处理机制。以事务处理的操作,要么都能成功执行,要么都不执行

事务的四个特点 ACID:
A:原子性:事务必须是原子工作单元;对于其数据修改,要么全都执行,要么全都不执行。它是一个整体,不能再拆分
C:一致性:事务在完成时,必须使所有的数据都保持一致状态。。某种程度的一致
I:隔离性:事务中隔离,每一个事务是单独的请求将单独的处理,与其它事务没有关系,互不影响
D:持久性:如果事务一旦提交,就对数据的修改永久保留

使用事务:
将你需要操作的sql命令包含在事务中
1.在事务的开启和事务的提交之间
2.在事务的开启和事务的回滚之间

三个关键语句:
开启事务:begin transaction
提交事务:commit transaction
回滚事务:rollback transaction

18.视图

视图就是一张虚拟表,可以像使用子查询做为结果集一样使用视图
select * from vw_getinfo
使用代码创建视图

语法:
create view vw_自定义名称
as
查询命令
go

19.触发器

触发器:执行一个可以改变表数据的操作(增加删除和修改),会自动触发另外一系列(类似于存储过程中的模块)的操作。

语法:
create trigger tr_表名_操作名称
on 表名 after|instead of 操作名称
as
go

20.存储过程

存储过程就相当于c#中的方法
参数,返回值,参数默认值,参数:值的方式调用
在调用的时候有三个对应:类型对应,数量对应,顺序对应

创建语法:
create proc usp_用户自定义名称
对应方法的形参 –(int age, out string name)
as
对应方法体:创建变量,逻辑语句,增加删除修改和查询..return返回值
go

调用语法:
exec 存储过程名称 实参,实参,实参 …

21.分页存储过程

22.索引

23.临时表

1 7 收藏 评论

相关文章

可能感兴趣的话题



直接登录
跳到底部
返回顶部