[SQL] SQL SERVER基础语法
Struct Query Language
1.3NF
a.原子性
b.不能数据冗余
c.引用其他表的主键
2.约束
a.非空约束
b.主键约束
c.唯一约束
d.默认约束
e.检查约束
f.外键约束
3.外键与关系
外键是约束,不做外键处理,关系也是存在的.
4.char varchar nchar nvarchar
char:是固定字符,如果不够,会用空格来处理. 不需要计算长度,速度快.
varchar:是动态的大小.需要计算长度,速度慢,存储占用小.
nvarchar:是以unicode编码存储.每个字符占2个字节.可以在任何sql server都能正常显示中文.不带n的英文占1个字节.中文占2个字节
5.crud
[select]:
取前5:select top 5
取前5%:select top 5 percent
去除重复:select distinct
条件:select * from 表名 where
[insert]:insert into 表名[(字段名,字段名)] values(字段值,字段值)
[update]:update 表名 set 字段名=字段值 [where]
[delete]:delete [from] 表名 [where]
6.运算符优先级
[逻辑运算符]: and or not(!)
[比较运算符]:< > = !=
比较运算符一般逻辑运算符优先级要高,除了not.!只比小括号的优先级低.
7.模糊查询
like:select * from 表名 where 字段名 like 值
_:匹配任意一个字符
%:匹配任意多个字符
[%]:匹配字符%
8.空值处理
ISNULL:select ISNULL(english,'缺考') from Scroe 英语成绩为空则显示缺考
is [not] null:select * from Scroe where english is null 把英语成绩为null的查询出来
9.聚合函数
SUM AVG COUNT MAX MIN
聚合函数一般和group by配合使用,having可以对group by后再过滤
10.完整查询语句顺序
select top 5 distinct * from T where field = fieldValue group by field2 having field2>5 order by field
1:from T 2:* 3:where 4:distinct 5:group by field2 6:having field2>5 7:order by 8:top 5
11.常用函数
[类型转换]:CAST(值 as 类型) CONVERT(类型,值)
[字符串]:LTRIM(值) RTRIM(值) LOWER(值) UPPER(值) LEN(值) SUBSTRING(值,开始位置,长度)
[日期]:GETDATE()取现在时间 DATEADD(datepart,number,date)加时间date+num DATEDIFF(datepart,startdate,enddate)取时间差end-start DATEPART(datepart,date)
取消/强制插入标识列:set identity_insert 表名 off/on
清空表:truncate table 表名
12.复制表
select * into 新表 from 原表 where 1=1
13.联合查询
当2个结果集列数相同,类型相同,可以合并为一个结果集.
union:会自动去除重复行
union all:显示所有行.
14.连接查询
分内连接和外连接
内连接:[inner ]join
select * from T1 inner join T2 on T1.ID2 = T2.ID
自连接是特殊的内连接,树结构存储: select * from T as T1 join T as T2 where T2.PID = T1.ID
外连接:
left [outer] join:左连接,左表内容全部显示.右边没有的用NULL标示
right [outer] join:右连接,右表内容全部显示.左边没有的用NULL标示
full [outer] join:全连接,左右表内容全部显示,没有的用NULL标示
15.开窗函数
可以将多行合并为一个区来看待.可以对一个区进行统计.区别于group by,可以查询所有列.
开窗函数:over() 里面可以跟order by和partition by(类似 group by)
排名:rank() over(order by id)
排序:row_number() over(order by id)
小计:avg(cost) over(partition by cost)(平均费用)
16.视图
本质封装一个sql语句,不会存储任何数据.
创建: create view viewName as sql语句
查看sql: exec sp_helptext viewName
17.事务
事务是保证多个操作同时成功或者同时失败
begin tran(开始事务) commit tran(提交事务) rollback tran(回滚事务)
打开/关闭事务自动提交:set implicit_transactions off/on
18.存储过程
存储过程本质是封装一段代码.
创建: create proc procName
@param1 int,@param2 int output
as
set @param2 =@param1 * @param1
参数默认值:存储过程只有最后一个参数可以有默认值.
19.索引
[聚焦索引]:
[非聚焦索引]:
create index indexName on tableName(fieldName)
20.触发器
对某个表的进行增删改操作时,自动执行一个操作.有2种方式执行,1是触发源操作前替换执行 2是触发源操作后执行
临时表:inserted deleted
2种方式:after | instead of
3种触发源:insert update delete
创建:
create trigger triggerName
after insert
as begin
insert into T select * from inserted
end
建议:影响效率 谨慎使用
21.游标
逐行的操作数据
对每条数据执行指定的
使用:(让T表中每个人的年龄增1)
declare c1 cursor for
select id,age from T
declare @id int
declare @age int
open c1
fetch c1 into @id,@age
while(@@FETCH_STATU = 0)
begin
set @age= 1 + @age
update T set age = @age where id = @id
fetch c1 into @id,@age
end
close c1
deallocate c1
[SQL] SQL SERVER基础语法的更多相关文章
- Sql Server 基础语法
来自:http://www.cnblogs.com/AaronYang/archive/2012/04/24/2468093.html Sql Server 基础语法 -- 查看数据表 select ...
- sql server 基础语法4 实践练习+子查询
drop table class create table class ( classId ) primary key not null, cName ) ) insert into class ', ...
- sql server 基础语法2
别名,选择,查询,排序,去重,筛选 select * from UserInfo as ui --起别名 select UserName,UserPwd --指定选择的列 from UserInfo ...
- 总结sql用法及基础语法 第一章 三范式
第一范式(1NF)设置了一个有组织的数据库非常基本的规则: 定义所需要的数据项,因为它们成为在表中的列.放在一个表中的相关的数据项. 确保有数据没有重复的组. 确保有一个主键. PRIMARY KEY ...
- sql server 基础教程[温故而知新三]
子曰:“温故而知新,可以为师矣.”孔子说:“温习旧知识从而得知新的理解与体会,凭借这一点就可以成为老师了.“ 尤其是咱们搞程序的人,不管是不是全栈工程师,都是集十八般武艺于一身.不过有时候有些知识如果 ...
- ASP.NET实现二维码 ASP.Net上传文件 SQL基础语法 C# 动态创建数据库三(MySQL) Net Core 实现谷歌翻译ApI 免费版 C#发布和调试WebService ajax调用WebService实现数据库操作 C# 实体类转json数据过滤掉字段为null的字段
ASP.NET实现二维码 using System;using System.Collections.Generic;using System.Drawing;using System.Linq;us ...
- SQL SERVER常用语法汇总
阅读目录 一.SQL分类 二.基础语句 三.sql技巧 四.(MS SQL Server)SQL语句导入导出大全 回到目录 一.SQL分类 DDL—数据定义语言(CREATE,ALTER,DROP,D ...
- 【SQL server】SQL server基础(二)
一.一些重要的SQL命令 SELECT - 从数据库中提取数据 UPDATE - 更新数据库中的数据 DELETE - 从数据库中删除数据 INSERT INTO - 向数据库中插入新数据 CREAT ...
- SQL Server基础知识
1.SQL Server表名为什么要加方括号? 这个不是必须要加,但表名或字段名如果引用了sqlserver中的关键字,数据库会不识别这到底是关键字还是表名(或字段名)时就必须要加. 比如,一个表名叫 ...
随机推荐
- JAVA自已设计JSON解析器
当然,有很多很好的JSON解析的JAR包,比如JSONOBJECT,GSON,甚至也有为我们测试人员而打造的JSONPATH,但我还是自已实现了一下(之前也实现过,现在属于重构). 思想是这样的,以这 ...
- Scala 深入浅出实战经典 第75讲:模式匹配下的For循环
王家林亲授<DT大数据梦工厂>大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频.PPT.代码下载: 百度云盘:http://pan.baidu.com/s/1c0noOt ...
- 解决部份机型toast不显示问题
问题:部份机型不显示toast 解决方案: 1.自己在设置里面去允许通知,但是显然客户会说别的app都可以,so 2.自定义解决.查看toast的源码发现其附着在window上 源码下载地址:http ...
- HDU 4759 Poker Shuffle
Poker Shuffle Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tot ...
- [转]说说C#的async和await
C# 5.0中引入了async 和 await.这两个关键字可以让你更方便的写出异步代码. 看个例子: public class MyClass { public MyClass() { Displa ...
- bash的循环中无法保存变量
在bash中,如果循环在一个子shell中运行,那么在循环中对循环外面的变量的更改将在循环退出后不可见.像下面的例子: #!/bin/sh python run.py | while read lin ...
- VC++ 学习笔记(二):VC++与C、VB和C#
罗马不是一天建成的,VC++的也不是凭空产生的——它一直标榜自己的从C发展而来的.VB好像是专门为了羞辱VC++而创建的.C#呢,是微软类C语言的新秀——其实也不新了.乱吧?貌似挺乱的,其实这里有章可 ...
- volley中图片加载
volley图片加载有三种方式: 记得:Volley中已经实现了磁盘缓存了,查看源码得知通过 context.getCacheDir()获取到了 /data/data/<application ...
- 严重: Exception starting filter struts2解决方法!
转自:http://blog.knowsky.com/260578.htm 问题出现: 严重: Exception starting filter struts2java.lang.ClassNotF ...
- java之对象转型
对象转型(casting) 1.一个基类的引用类型变量可以“指向”其子类的对象. 2.一个基类的引用不可以访问其子类对象新增加的成员(属性和方法). 3.可以使用 引用变量 instanceof 类名 ...