学习T-SQL时记录的笔记,记得并不全也不详细

if和while语句

declare @age int
select @age = DATEDIFF(year,stuAge,getdate()) from TbStudent where stuName = '孙悟空' if(@age>=18)
begin --必须有begin..end
print N'已成年'
end
else
begin
print N'未成年'
end
declare @sum int
set @sum = 0
declare @i int
set @i = 1
while(@i <= 100)
begin
if(@i % 2 <> 0)
begin
set @sum = @sum + @i
end
set @i = @i + 1
end
print @sum

自定义函数

分为标量函数、表值函数(内联表值函数和多语句表值函数)

标量函数:只返回一个基础类型数据的值

-- 语法
create function 函数名
([参数列表]) 可以不写参数,先写变量名再写类型
returns 返回值类型
as
begin
-- ······函数体语句
return 返回值
end

表值函数:返回一个table类型的结果集

内联表值函数

-- 语法
create function 函数名
([参数名])
returns table
as
return (一条select语句)

多语句表值函数

多语句表值函数可以看作是标量函数和内联表值函数的结合体

-- 语法
create function 函数名([参数列表])
returns 表变量名 table
(表变量的字段定义)
as
begin
SQL
return 这里啥都不写
end

注意

  • SQL自定义函数必须有返回值
  • 在自定义函数中不允许修改基表内容(即,不能用insert,update,delete)
  • 如果有多个参数,每个参数一之间用逗号隔开
  • 调用函数时,函数名前要加dbo.

存储过程

存储过程时存储在服务器上的一组T-SQL语句的集合,用来完成一个特定功能。

分为系统存储过程(系统自带)和自定义存储过程

自定义存储过程

-- 语法
create procedure(或proc) 存储过程名(up_)
[参数列表] --这里的参数列表不能使用圆括号
begin
存储过程代码
end

注意:

  • 存储过程可以没有返回值
  • 存储过程不适用return语句带回返回值,如果有返回值,直接使用select语句返回

索引

  • 索引:创建在表上
  • 作用: 加快检索速度
  • 全表扫面
  • 索引分为聚集索引和非聚集索引
  • 聚集索引: 在一个数据表中,只能创建一个聚集索引
  • 主键会默认创建一个聚集索引
  • 在你经常使用where的字段上添加非聚集索引
  • 缺点:占用额外的存储空间,有可能降低insert、update、delete的速度

事务

事务时并发控制的单位,他是用户定义的一个操作,这些操作要么都做要么都不做,不可分割。

分为:SQL Server事务和ADO.NET事务

-- 语法
begin tran --开始一个事务操作
commit tran --提交
rollback --回滚

C#中使用时,通常把事务的操作封装到存储过程中

触发器

  • 触发器是一种特殊的存储过程
  • 只不过这个存储过程是不允许显示调用的
  • 他只能在做了特定事件后,自动触发做出响应的
  • 两张临时数据表:inserted、deleted
  • 只能在触发器中访问
  • 触发器是附着在一张表上的
-- 语法
create trigger 触发器名字
on 表名
after(或for) 之后触发 / instead of 之前触发 [insert/delete/update]
as
begin
-- ······
end

触发器的触发条件:insert,delete,update

create trigger tr_Bank_insert
on Bank
after insert
as
begin
print '往Bank表中插入了记录'
end create trigger tr_Bank_Delete
on Bank
after delete
as
begin
declare @id int
declare @userName nvarchar(8)
declare @userMoney int
select @id = id, @userMoney = userMoney, @userName = userName from deleted
insert into BankBak values(@id, @userName, @userMoney)
end select * from Bank
select * from BankBak delete from Bank where id = 3

SQL Server的触发器是表级触发器,表上一次性的多次操作只触发一次

T-SQL学习笔记的更多相关文章

  1. ORALCE PL/SQL学习笔记

    ORALCE  PL/SQL学习笔记 详情见自己电脑的备份数据资料

  2. Oracle之PL/SQL学习笔记

    自己在学习Oracle是做的笔记及实验代码记录,内容挺全的,也挺详细,发篇博文分享给需要的朋友,共有1w多字的学习笔记吧.是以前做的,一直在压箱底,今天拿出来整理了一下,给大家分享,有不足之处还望大家 ...

  3. SQL学习笔记

    SQL(Structured Query Language)学习笔记 [TOC] Terminal登录数据库 1.登录mysql -u root -p ; 2.显示所有数据库show database ...

  4. [SQL学习笔记][用exists代替全称量词 ]

    学习sql的必经问题. 学生表student (id学号 Sname姓名 Sdept所在系) 课程表Course (crscode课程号 name课程名) 学生选课表transcript (studi ...

  5. SQL学习笔记——SQL初入门,Ubuntu下MySQL的安装

          刚开始接触sql,于是准备在Ubuntu下学习sql,就跟着itercast的sql教程开始入门了. 下面只是我个人的记录,高手请绕道: 一. 在安装之前,我们可以用下面这个命令通过开放端 ...

  6. pl/sql学习笔记---马士兵教程38-48

    Procedure Language/Structure query Language 一.关于语言学习 1.数据类型 2.语法   通过例子来学习很快就能明白 set serverputout on ...

  7. SQL学习笔记之SQL查询练习题1

    (网络搜集) 0x00 表名和字段 –1.学生表 Student(s_id,s_name,s_birth,s_sex) –学生编号,学生姓名, 出生年月,学生性别 –2.课程表 Course(c_id ...

  8. SQL学习笔记之MySQL索引知识点

    0x00 概述 之前写过一篇Mysql B+树学习,简单的介绍了B+数以及MySql使用B+树的原因, 有了这些基础知识点,对MySql索引的类型以及索引使用的一些技巧,就比较容易理解了. 0x01 ...

  9. SQL学习笔记:一些高级语句

    现在以MySQL为模板.学习的方法和别的数据库写法上会有不同,但是思路基本一致. 用到的数据库表的格式: +----+--------------+-------------------------- ...

  10. SQL学习笔记:基础SQL语句

    目录 语句特点 进入数据库 基本查询语句 SELECT DISTINCT WHERE AND/OR/NOT :逻辑运算符 ORDER BY :排序 基本修改语句 INSERT:添加语句 UPDATE: ...

随机推荐

  1. IDEA_2019.2的安装与个人配置(Windows)

    1. 下载 官方下载网站:https://www.jetbrains.com/idea/download/ IDEA是支持多平台的开发工具,分为Windows.Mac和Linux三个平台,这里就只拿W ...

  2. ubuntu之路——day2

    一:sougou输入法安装 详情参考:https://blog.csdn.net/xin17863935225/article/details/82285177 注意切换成fcitx架构 因为linu ...

  3. SetThreadAffinityMask windows下绑定线程(进程)到指定的CPU核心

    原帖地址:https://www.cnblogs.com/lvdongjie/p/4476766.html 一个程序指定到单独一个CPU上运行会比不指定CPU运行时快.这中间主要有两个原因:1)CPU ...

  4. vim脚本判断操作系统

    Linux 和 Windows 通用配置 其实在配置文件中是可以通过逻辑代码判断平台做条件处理的,这样就可以实现一个配置文件两个个平台下共用了,判断逻辑如下: " ============= ...

  5. java类型 jdbcType类型 mysql类型关系

    java类型 jdbcType类型 mysql类型关系 Java类型 JdbcType Mysql类型 备注 String VARCHAR VARCHAR 变长字符串 String LONGVARCH ...

  6. zabbix使用fping监控任意两个节点之间的网络质量、丢包率和响应时间

    zabbix使用fping监控任意两个节点之间的网络质量.丢包率和响应时间 之前的博文 使用zabbix3..4的ICMP Ping模版实现对客户端网络状态的监控 https://www.cnblog ...

  7. 从Windows转mac遇到的一些坑

    本屌由于运气,分了一台imac来办公,由于以前一直都在用windows,现在用Mac有很多不适应的地方.下面介绍一下Mac与Windows有明显区别的地方: mac与windows鼠标滑轮方向不同. ...

  8. Spring cloud微服务安全实战-4-6搭建OAuth2资源服务器

    认证服务器已经搭建好了. 可以通过认证服务器拿到令牌 下面改造订单服务,让它可以用这个令牌. 争对订单服务要做三个事, 1.让订单服务知道它自己是Oauth协议里面的资源服务器.,它知道这个事后,它才 ...

  9. bladex之nacos配置

    blade.yaml #服务器配置server:  undertow:    # 设置IO线程数, 它主要执行非阻塞的任务,它们会负责多个连接, 默认设置每个CPU核心一个线程    io-threa ...

  10. LwIP应用开发笔记之一:LwIP无操作系统基本移植

    现在,TCP/IP协议的应用无处不在.随着物联网的火爆,嵌入式领域使用TCP/IP协议进行通讯也越来越广泛.在我们的相关产品中,也都有应用,所以我们结合应用实际对相关应用作相应的总结. 1.技术准备 ...