SQLServer学习笔记系列10

一.写在前面的话

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

二.死锁

在Sql中,当我们想访问某个资源时,而此时正好对方的资源也想访问你所持有的资源时,那么就会出现死锁。就好比两个人互相握住对方的双手,那么此时两个人都无法解脱出来,都被束缚了(死锁)。我们看例子吧:

打开两个会话(54号、57号):

54号会话:

 1 USE TSQLFundamentals2008;
 2 BEGIN  TRANSACTION;
 3 UPDATE Production.Products
 4 SET unitprice=unitprice+1
 5 WHERE  productid=2
 6
 7 --在51号会话中准备修改57会话中的数据
 8 UPDATE  Sales.OrderDetails
 9 SET unitprice=unitprice+1
10 WHERE productid =2;

57号会话:

 1 USE TSQLFundamentals2008;
 2 BEGIN TRANSACTION;
 3
 4 --更新操作获取到独占锁
 5 UPDATE  Sales.OrderDetails
 6 SET unitprice=unitprice+1
 7 WHERE productid =2;
 8
 9
10 --在57号会话中更新54号会话数据
11 UPDATE Production.Products
12 SET unitprice=unitprice+1
13 WHERE  productid=2

此时,54号、57号会话都做了事务更新操作,那么两者都独自占有了资源。如果54号同时想更新57号的里面的记录了?57号也想更新54号会话的记录?此时就会处出现死锁。

我们可以看看运行的结果:

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

三.T-SQL编程

1.定义变量

(1)常量:

1 DECLARE  @s INT;
2 SET @s=10;
3 PRINT @s;

(2)字符类型:

1 DECLARE @str NVARCHAR;
2 SET @str =‘Hello World‘;
3 PRINT @str;

此时打印出来的结果为:

因为给str 声明为nvarchar时,没有给定长度,所以一定要注意给字符定义长度;同时还可以用select对变量赋值:

1 DECLARE @m NVARCHAR(100);
2 SELECT @m=99;
3 PRINT @m;

查询顾客的数量,保存到变量中:

2.流程控制

(1)if......else

例子:根据当前时间来决定干什么(睡觉or学习)

(2)while

例子:高斯问题

3.游标

游标在我们的使用中不常使用,因为游标所带来的开销比较大,所以对于集合处理,能用sql解决的,就尽量不适用游标,根据具体业务来定。

现在有这样一个需求,我们要查询出所有的客户公司名称,进而进行其他的业务处理:

有人可能会想到用变量处理,接受查询出来的结果:

所以变量时无法获得的,考虑用游标怎么获得。

游标的使用:

 1 --1.声明游标,基于查询
 2 DECLARE c CURSOR
 3 FOR
 4 SELECT companyname
 5 FROM Sales.Customers;
 6
 7 DECLARE @name NVARCHAR(100);
 8
 9 --2.在使用时候,必须打开游标
10 OPEN c;
11
12 --3.从游标中读取数据,每次可以读取出来一条数据
13 FETCH NEXT FROM c INTO @name;
14
15 --4.注意fetch,并不一定能获得实际的数据
16 WHILE  @@fetch_status=0
17 BEGIN
18 PRINT @name;
19 FETCH NEXT FROM c INTO @name;
20
21 END;
22
23 --5.游标使用完成以后,一定要关闭
24 CLOSE c;
25
26 --6.释放游标
27 DEALLOCATE c;

执行结果:

4.临时表

(1)局部临时表

创建临时表,注意临时表表名前需要加(#):

1 CREATE TABLE #tempdb
2 (
3  num INT
4 )
5
6 INSERT INTO #tempdb
7         ( num )
8 VALUES  (1),(2),(3),(4),(5)

(2)全局临时表

名字前面带##:以两个井号 (##) 开头的那些表名。在所有连接上都能看到全局临时表。如果在创建全局临时表的连接断开前没有显式地除去这些表,那么只要所有其它任务停止引用它们,这些表即被除去。当创建全局临时表的连接断开后,新的任务不能再引用它们。当前的语句一执行完,任务与表之间的关联即被除去;因此通常情况下,只要创建全局临时表的连接断开,全局临时表即被除去。

CREATE TABLE ##tempdb
(
 name NVARCHAR(100)
)

INSERT INTO ##tempdb
        ( name )
VALUES  (‘mm‘)

5.动态Sql

动态sql语句,用于将sql语句封装成一条字符串记录。

首先看看静态sql,也就是查询的字段确定的查询语句即为静态sql语句,比如查询客户的公司名称

1 --静态sql
2 SELECT companyname
3 FROM  Sales.Customers; 

动态sql:

1 DECLARE @sql NVARCHAR(100);
2 SET @sql=‘SELECT custid,companyname
3 FROM  Sales.Customers‘;
4
5 EXEC(@sql);

执行结果:

在这要提醒一点的就是Sql的注入攻击,因为当sql语句作为执行时候,那么用户的输入就是邪恶的,存在漏洞。比如:

1 DECLARE @sql NVARCHAR(100);
2 SET @sql=‘SELECT custid,companyname
3 FROM  Sales.Customers where custid=‘;
4
5 DECLARE @input NVARCHAR(100);
6 SET @input =‘0; select * from Sales.Customers‘;
7 SET @[email protected]+@input;
8 EXEC(@sql);

执行结果:

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

关于sql注入,需要仔细研究,这里说的很浅显,希望可以进一步学习!

希望各位大牛给出指导,不当之处虚心接受学习!谢谢!

时间: 2024-10-10 04:39:35

SQLServer学习笔记系列10的相关文章

SQLServer学习笔记系列1

本系列博文转载自http://www.cnblogs.com/liupeng61624/category/668878.html 本人是新入行的小菜鸟,希望转载一些博文和大家一起学习!谢谢! SQLServer学习笔记系列1 一.前言 一直自己没有学习做笔记的习惯,所以为了加强自己对知识的深入理解,决定将学习笔记写下来,希望向各位大牛们学习交流!不当之处请斧正!在此感谢! 这边就先从学习Sqlserver写起,自己本身对数据库方面不擅长,所以决定对此从基础开始学习,大牛们对此文可以忽略!首先以<

SQLServer学习笔记系列2

SQLServer学习笔记系列2 一.写在前面的话 继上一次SQLServer学习笔记系列1http://www.cnblogs.com/liupeng61624/p/4354983.html以后,继续学习Sqlserver,一步一步走下去,相信努力终会 有收获!一直坚信这句话,这个世界上比你优秀的人很多,他们在你休息的时候,勤勤恳恳的做着我们看不到的事情,但你回首往事的时候,真心觉得那段奋 斗的岁月让你骄傲!年轻就得折腾,年轻就要奋斗!好啦,进入正题吧! 二.sql的范围内查找 (1)betw

SQLServer学习笔记系列3

一.写在前面的话 今天又是双休啦!生活依然再继续,当你停下来的时候,或许会突然显得不自在.有时候,看到一种东西,你会发现原来在这个社会上,优秀的人很多,默默 吃苦努力奋斗的人也多!星期五早上按时上班,买好早餐,去公司餐厅吃早餐,我遇见了一个人,也许一次两次我还不会去注意,然而我每次在餐厅吃早餐, 都会遇到他,我看到他的是每一次都带着一碗白粥在那里吃,甚至连一点咸菜都没用,或许我这样的单身狗,不能理解有家室的痛楚,也许这是他的一种生活 方式,但我更多的看到的是他的一种吃苦,为了家人,为了将来的一种

SQLServer学习笔记系列6

一.写在前面的话 时间是我们每个人都特别熟悉的,但是到底它是什么,用什么来衡量,可能很多人会愣在那里.时间可以见证一切,也可以消磨一切,那些过往的点点滴滴可思可忆.回想往年清明节过后,在家乡的晚上总能听见阵阵的青蛙叫声,那是清脆的叫声,那是家乡的味道.时间一转眼,貌似那些日子已离我远去好久,在城市的喧嚣浮华中,找寻不到那种内心的宁静.感叹时间流逝的同时,怀念过去的点点滴滴.我想在繁华的都市中寻找一种安定的心情来学习,或许是一种不错的方式.学习才会让我们认清自己,找回自我,做内心的强者,不骄不躁,

SQLServer学习笔记系列5

一.写在前面的话 转眼又是一年清明节,话说“清明时节雨纷纷”,武汉的天气伴随着这个清明节下了一场暴雨,整个城市如海一样,朋友圈渗透着清明节武汉看海的节奏.今年又没有回老家祭祖,但是心里依然是怀念着那些亲人,虽说他们已离我们远去,然而那些血浓于水的亲情是一辈子无法忘记的,在心里深深的想念他们.生活继续,激情永恒!时刻保持着奋斗的节奏,为那些爱我们的和我爱的人,好好活着,做一个斗士,让我们都能够获得幸福!继续我们的学习吧!在这里首先分享海子的一首诗: 面对大河我无限惭愧, 我年华虚度,空有一身疲倦,

SQLServer学习笔记系列4

一.写在前面的话 好多天没有记录sql学习笔记了,要坚持下去,坚信每一点的进步都是为在积蓄力量.今天看到一幅图,特此分享出来. 通过这幅图,我看到的是每人站在自己的角度看问题,感受是不一样的,就如同学习知识一样,总觉得自己的理解才是最独特的,有时候适当把东西分享出 去,听听别人的见解,或许会让我们理解的更加深刻.换位思考,冷静处理,沉着淡定,不骄不躁,bug只不过生活的一部分,正因为有了bug才会让我们进 步,让我们去学习,去追寻问题的答案,一起努力,做一个快乐的程序猿.这个世界唯一不变的就是变

SQLServer学习笔记系列12

一.写在前面的话 这个sql学习系列,今天准备告一段落,虽然短短的十几篇文章,深刻感受到将学习的东西记录下来,是需要一种坚持! 这些东西只有反复的学习吸收,最终沉淀下来的才是属于自己的知识.也是提醒自己,今后的日子更要有计划,转眼又是7月份了, 时间不等人,岁月不饶人!坚持自己的计划,坚持向往的东西,踏实学习,因为自己不会的还太多,那些大牛还在学习, 我就更没理由逃避!也希望结交一些朋友,一起讨论技术,一起学习,一起进步!   二.触发器 触发器是一种特殊类型的存储过程,不能被显示的执行.它所监

SQLServer学习笔记系列11

一.写在前面的话 身体是革命的本钱,这句放在嘴边常说的话,还是拿出来一起共勉,提醒一起奋斗的同僚们,保证睡眠,注意身体!偶尔加个班,也许不曾感觉到身体发出的讯号,长期晚睡真心扛不住!自己也制定计划,敦促自己按照作息时间来上班学习生活!虽然自己每星期运动,还是觉得晚睡带来的身体压力,无法承受!程序猿兄弟们,我们早上起来的时候,可以看看自己的眼睛,如果充满血丝,那我们就该需要调养,好好休息了!没了身体,Coding的世界即将一去不复返!好好休息,保重身体!善待朋友,真爱家人,迎接每一天美丽的日出!共

SQLServer学习笔记系列7

一.写在前面的话 转眼又是周一,回想双休的日子,短暂而幸福,在阳光明媚的下午,可以自己做自己想做的任何事,惬意舒适,或读书,或运动,或音乐,当我们静下心来慢慢感受这些的时候,会突然发觉,原来生活是这么的幸福!有所求,有所感,就够啦!简简单单的生活其实就是最奢华的享受!忘记不开心的事,做自己生活的主导,摆脱烦恼,希望园子的朋友们,都能有一个好心情,不顺心的时候,出去走走,让情绪行走无边,放空自己!相信美好的事情终将发生! 二.视图 视图可以看作定义在SQL Server上的虚拟表.视图包含查询的一