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基础语法的更多相关文章

  1. Sql Server 基础语法

    来自:http://www.cnblogs.com/AaronYang/archive/2012/04/24/2468093.html Sql Server 基础语法 -- 查看数据表 select  ...

  2. sql server 基础语法4 实践练习+子查询

    drop table class create table class ( classId ) primary key not null, cName ) ) insert into class ', ...

  3. sql server 基础语法2

    别名,选择,查询,排序,去重,筛选 select * from UserInfo as ui --起别名 select UserName,UserPwd --指定选择的列 from UserInfo ...

  4. 总结sql用法及基础语法 第一章 三范式

    第一范式(1NF)设置了一个有组织的数据库非常基本的规则: 定义所需要的数据项,因为它们成为在表中的列.放在一个表中的相关的数据项. 确保有数据没有重复的组. 确保有一个主键. PRIMARY KEY ...

  5. sql server 基础教程[温故而知新三]

    子曰:“温故而知新,可以为师矣.”孔子说:“温习旧知识从而得知新的理解与体会,凭借这一点就可以成为老师了.“ 尤其是咱们搞程序的人,不管是不是全栈工程师,都是集十八般武艺于一身.不过有时候有些知识如果 ...

  6. 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 ...

  7. SQL SERVER常用语法汇总

    阅读目录 一.SQL分类 二.基础语句 三.sql技巧 四.(MS SQL Server)SQL语句导入导出大全 回到目录 一.SQL分类 DDL—数据定义语言(CREATE,ALTER,DROP,D ...

  8. 【SQL server】SQL server基础(二)

    一.一些重要的SQL命令 SELECT - 从数据库中提取数据 UPDATE - 更新数据库中的数据 DELETE - 从数据库中删除数据 INSERT INTO - 向数据库中插入新数据 CREAT ...

  9. SQL Server基础知识

    1.SQL Server表名为什么要加方括号? 这个不是必须要加,但表名或字段名如果引用了sqlserver中的关键字,数据库会不识别这到底是关键字还是表名(或字段名)时就必须要加. 比如,一个表名叫 ...

随机推荐

  1. parallels无法启动之大乌龙-流水账版

    欢迎访问我的blog:blog.thinkinside.me     早上到公司,像往日一样,开电脑倒茶喝水. 回到座位打开parallels desktop,发现不对,打开PD非常的慢.显示正在初始 ...

  2. 小试ijkplayer编译

    同步发表于 http://avenwu.net/ijkplayer/2015/05/07/hands_on_ijkplayer_preparation 谈到视频播放大家都知道ffmpeg,基于其的衍生 ...

  3. [CoreOS 转载] CoreOS实践指南(五):分布式数据存储Etcd(上)

    转载:http://www.csdn.net/article/2015-01-22/2823659 摘要:在“漫步云端:CoreOS实践指南”系列的前几篇,分别介绍了如何架设CoreOS集群,系统服务 ...

  4. CSS3学习笔记——伪类hover

    最近看到一篇文章:“Transition.Transform和Animation使用简介及应用展示”    ,想看看里面 “不同缓动类效果demo”例子的效果,发现了一个问题如下: .Trans_Bo ...

  5. Linux下配置ip地址四种方法

    linux系统安装完,以后通过命令模式配置网卡IP.配置文件通常是/etc/sysconfig/network-scripts/ifcfg-interface-nameifconfig后显示的内容,l ...

  6. Pro ASP.NET MVC –第四章 语言特性精华

    C#语言有很多特性,并不是所有的程序员都了解本书我们将会使用的C#语言特性.因此,在本章,我们将了解一下作为一个好的MVC程序员需要了解C#语言的特性. 每个特性我们都只是简要介绍.如果你想深入了解L ...

  7. Java基础集锦——利用Collections.sort方法对list排序

    要想对List进行排序,可以让实体对象实现Comparable接口,重写compareTo方法即可实现按某一属性排序,但是这种写法很单一,只能按照固定的一个属性排序,没变法变化.通过下面这种方法,可以 ...

  8. 老鼠跑猫叫主人惊醒c++观察者模式实现

    这个题目算是比较经典的观察者模式了,老鼠作为一个Subject,主动发出跑的动作,紧跟着猫由于老鼠的跑而发出叫声,主人也被惊醒,在这里猫跟主人都是被动的,是观察者角色,代码实现如下: class CS ...

  9. ALTER SEQUENCE 修改序列解决唯一约束冲突 unique constraint violated

    背景 自增序列会遇到也会遇到唯一约束冲突吗?是的,最常见的情况就是数据迁移之后,导致数据最大值超过序列值. 软件开发中不遇到些出乎意料的问题,总感觉不太够劲. 修改序列(ALTER SEQUENCE) ...

  10. jade模板引擎学习笔记(WebsStorm9.0.3+ nodejs+express+jade)

    jade环境搭建 jade标签写法 jade注释 jade添加类名.id.属性 jade添加脚本,css jade变量 jade多行文本显示 jade流程代码:for,each,while jade流 ...