SQLServer学习笔记系列10
一.写在前面的话
生活的路很长,还是要坚持走下去,自己选择的生活,就该让这样的生活放射精彩!我不奢求现在的积累,在将来能够收获多少,至少在以后的日子里回忆起来,我不曾放弃过,我坚持过,我不后悔!最近跟朋友谈到成长的话题,我们似乎摆脱不了被敦促的年纪,结婚、下一代是父母对我们的期盼,不同的年龄看问题的方式或许不同,真的到了他们那个年龄,我们才能真正体会那种心情,那种期盼!我只想告诉父母们,我们会努力的!走进未来的幸福,也是我们追求的,只是在这条路上,我们需要更大的勇气努力!你们好好保重,幸福会来的!

二.死锁
在Sql中,当我们想访问某个资源时,而此时正好对方的资源也想访问你所持有的资源时,那么就会出现死锁。就好比两个人互相握住对方的双手,那么此时两个人都无法解脱出来,都被束缚了(死锁)。我们看例子吧:
打开两个会话(54号、57号):
54号会话:
USE TSQLFundamentals2008;
BEGIN TRANSACTION;
UPDATE Production.Products
SET unitprice=unitprice+
WHERE productid= --在51号会话中准备修改57会话中的数据
UPDATE Sales.OrderDetails
SET unitprice=unitprice+
WHERE productid =;
57号会话:
USE TSQLFundamentals2008;
BEGIN TRANSACTION; --更新操作获取到独占锁
UPDATE Sales.OrderDetails
SET unitprice=unitprice+
WHERE productid =; --在57号会话中更新54号会话数据
UPDATE Production.Products
SET unitprice=unitprice+
WHERE productid=
此时,54号、57号会话都做了事务更新操作,那么两者都独自占有了资源。如果54号同时想更新57号的里面的记录了?57号也想更新54号会话的记录?此时就会处出现死锁。
我们可以看看运行的结果:

通过结果我们可以看到,sql内部会对死锁有一个机制,即选择死锁牺牲品,由于54号会话所做操作牺牲的代价小一些,所以被牺牲了!此时可以看到57号已做了更新操作!

三.T-SQL编程
1.定义变量
(1)常量:
DECLARE @s INT;
SET @s=;
PRINT @s;
(2)字符类型:
DECLARE @str NVARCHAR;
SET @str ='Hello World';
PRINT @str;
此时打印出来的结果为:

因为给str 声明为nvarchar时,没有给定长度,所以一定要注意给字符定义长度;同时还可以用select对变量赋值:
DECLARE @m NVARCHAR();
SELECT @m=;
PRINT @m;
查询顾客的数量,保存到变量中:

2.流程控制
(1)if......else
例子:根据当前时间来决定干什么(睡觉or学习)

(2)while
例子:高斯问题

3.游标
游标在我们的使用中不常使用,因为游标所带来的开销比较大,所以对于集合处理,能用sql解决的,就尽量不适用游标,根据具体业务来定。
现在有这样一个需求,我们要查询出所有的客户公司名称,进而进行其他的业务处理:
有人可能会想到用变量处理,接受查询出来的结果:

所以变量时无法获得的,考虑用游标怎么获得。
游标的使用:
--.声明游标,基于查询
DECLARE c CURSOR
FOR
SELECT companyname
FROM Sales.Customers; DECLARE @name NVARCHAR(); --.在使用时候,必须打开游标
OPEN c; --.从游标中读取数据,每次可以读取出来一条数据
FETCH NEXT FROM c INTO @name; --.注意fetch,并不一定能获得实际的数据
WHILE @@fetch_status=
BEGIN
PRINT @name;
FETCH NEXT FROM c INTO @name; END; --.游标使用完成以后,一定要关闭
CLOSE c; --.释放游标
DEALLOCATE c;
执行结果:

4.临时表
(1)局部临时表
创建临时表,注意临时表表名前需要加(#):
CREATE TABLE #tempdb
(
num INT
) INSERT INTO #tempdb
( num )
VALUES (),(),(),(),()
(2)全局临时表
名字前面带##:以两个井号 (##) 开头的那些表名。在所有连接上都能看到全局临时表。如果在创建全局临时表的连接断开前没有显式地除去这些表,那么只要所有其它任务停止引用它们,这些表即被除去。当创建全局临时表的连接断开后,新的任务不能再引用它们。当前的语句一执行完,任务与表之间的关联即被除去;因此通常情况下,只要创建全局临时表的连接断开,全局临时表即被除去。
CREATE TABLE ##tempdb
(
name NVARCHAR()
) INSERT INTO ##tempdb
( name )
VALUES ('mm')
5.动态Sql
动态sql语句,用于将sql语句封装成一条字符串记录。
首先看看静态sql,也就是查询的字段确定的查询语句即为静态sql语句,比如查询客户的公司名称
--静态sql
SELECT companyname
FROM Sales.Customers;
动态sql:
DECLARE @sql NVARCHAR();
SET @sql='SELECT custid,companyname
FROM Sales.Customers'; EXEC(@sql);
执行结果:

在这要提醒一点的就是Sql的注入攻击,因为当sql语句作为执行时候,那么用户的输入就是邪恶的,存在漏洞。比如:
DECLARE @sql NVARCHAR();
SET @sql='SELECT custid,companyname
FROM Sales.Customers where custid='; DECLARE @input NVARCHAR();
SET @input ='0; select * from Sales.Customers';
SET @sql=@sql+@input;
EXEC(@sql);
执行结果:

防止此类现象发生,可以用严格意义的动态sql语句执行命令:sp_executesql

关于sql注入,需要仔细研究,这里说的很浅显,希望可以进一步学习!
希望各位大牛给出指导,不当之处虚心接受学习!谢谢!
SQLServer学习笔记系列10的更多相关文章
- SQLServer学习笔记系列2
一.写在前面的话 继上一次SQLServer学习笔记系列1http://www.cnblogs.com/liupeng61624/p/4354983.html以后,继续学习Sqlserver,一步一步 ...
- SQLServer学习笔记系列3
一.写在前面的话 今天又是双休啦!生活依然再继续,当你停下来的时候,或许会突然显得不自在.有时候,看到一种东西,你会发现原来在这个社会上,优秀的人很多,默默 吃苦努力奋斗的人也多!星期五早上按时上班, ...
- SQLServer学习笔记系列6
一.写在前面的话 时间是我们每个人都特别熟悉的,但是到底它是什么,用什么来衡量,可能很多人会愣在那里.时间可以见证一切,也可以消磨一切,那些过往的点点滴滴可思可忆.回想往年清明节过后,在家乡的晚上总能 ...
- SQLServer学习笔记系列5
一.写在前面的话 转眼又是一年清明节,话说“清明时节雨纷纷”,武汉的天气伴随着这个清明节下了一场暴雨,整个城市如海一样,朋友圈渗透着清明节武汉看海的节奏.今年又没有回老家祭祖,但是心里依然是怀念着那些 ...
- SQLServer学习笔记系列1
一.前言 一直自己没有学习做笔记的习惯,所以为了加强自己对知识的深入理解,决定将学习笔记写下来,希望向各位大牛们学习交流! 不当之处请斧正!在此感谢!这边就先从学习Sqlserver写起,自己本身对数 ...
- SQLServer学习笔记系列4
一.写在前面的话 好多天没有记录sql学习笔记了,要坚持下去,坚信每一点的进步都是为在积蓄力量.今天看到一幅图,特此分享出来. 通过这幅图,我看到的是每人站在自己的角度看问题,感受是不一样的,就如同学 ...
- SQLServer学习笔记系列12
一.写在前面的话 这个sql学习系列,今天准备告一段落,虽然短短的十几篇文章,深刻感受到将学习的东西记录下来,是需要一种坚持! 这些东西只有反复的学习吸收,最终沉淀下来的才是属于自己的知识.也是提醒自 ...
- SQLServer学习笔记系列11
一.写在前面的话 身体是革命的本钱,这句放在嘴边常说的话,还是拿出来一起共勉,提醒一起奋斗的同僚们,保证睡眠,注意身体!偶尔加个班,也许不曾感觉到身体发出的讯号,长期晚睡真心扛不住!自己也制定计划,敦 ...
- SQLServer学习笔记系列8
一.写在前面的话 最近一直在思考一个问题,什么才能让我们不显得浮躁,真正的静下心来,用心去感受,用心去回答每个人的问题,用心去帮助别人.现实的生活,往往让我们显得精疲力尽,然后我们仔细想过没用,其实支 ...
随机推荐
- 查询指定网段可用IP脚本
1.脚本内容: #vi hhh 添加以下内容: #!/bin/bash read -p "Please keyin the network segment: (e.g. 10.88.1) & ...
- 使用knockout-sortable实现对自定义菜单的拖拽排序
在开始之前,照例,我们先看效果和功能实现. 关于自定义菜单的实现,这里就不多说了,需要了解的请访问:http://www.cnblogs.com/codelove/p/4838766.html 这里需 ...
- Swift编程语言(中文版)官方手册翻译(进度8.8%)
翻译着玩,进度会比较慢. 等不及的可以看CocoaChina翻译小组,他们正在组织翻译,而且人手众多,相信会提前很多完成翻译. 原文可以在iTunes免费下载 目前进度 7 JUN 2014: 8.8 ...
- 分享:写了一个 java 调用 C语言 开发的动态库的范例
分享:写了一个 java 调用 C语言 开发的动态库的范例 cfunction.h 代码#pragma once#ifdef __cplusplusextern "C" {#e ...
- 【源码分享】WPF漂亮界面框架实现原理分析及源码分享
1 源码下载 2 OSGi.NET插件应用架构概述 3 漂亮界面框架原理概述 4 漂亮界面框架实现 4.1 主程序 4.2 主程序与插件的通讯 4.2.1 主程序获取插件注册的服务 4.2 ...
- ArcEngine 无法嵌入互操作类型
说明: 在.net 4.0中,声明 IPoint point = new PointClass();会出现下面这个错误 错误 2 类型"ESRI.ArcGIS.Geometry.PointC ...
- javascript 设计模式-----享元模式
四个轮子,一个方向盘,有刹车,油门,车窗,这些词首先让人联想到的就是一辆汽车.的确,这些都是是一辆车的最基本特征,或者是属性,我们把词语抽象出来,而听到这些词语的人把他们想象陈一辆汽车.在代码里面也是 ...
- C#中的线程二(Cotrol.BeginInvoke和Control.Invoke)
C#中的线程二(Cotrol.BeginInvoke和Control.Invoke) 原文地址:http://www.cnblogs.com/whssunboy/archive/2007/06/07/ ...
- 基于正则的INI读写工具类,支持加密解密
看到这个标题,有人会问,现在都用xml做配置文件了,谁还用INI文件啊!下面来简单对比一下xml和ini: 1.XML功能强大表达能力强,同时扩展性好. 2.它的主要优势是异构平台的整合.通讯. 3. ...
- http学习笔记(二)—— 嘿!伙计,你在哪?(URL)
我们之所以希望浏览网页,其中一个重要的原因就是庞大的web世界中有很丰富的资源,他就像哆啦a梦的口袋,随时都能拿出我们想要的宝贝.这些资源通过http被传送到我们的浏览器,并展示到我们的屏幕上.而我们 ...