一.写在前面的话

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

二.死锁

在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的更多相关文章

  1. SQLServer学习笔记系列2

    一.写在前面的话 继上一次SQLServer学习笔记系列1http://www.cnblogs.com/liupeng61624/p/4354983.html以后,继续学习Sqlserver,一步一步 ...

  2. SQLServer学习笔记系列3

    一.写在前面的话 今天又是双休啦!生活依然再继续,当你停下来的时候,或许会突然显得不自在.有时候,看到一种东西,你会发现原来在这个社会上,优秀的人很多,默默 吃苦努力奋斗的人也多!星期五早上按时上班, ...

  3. SQLServer学习笔记系列6

    一.写在前面的话 时间是我们每个人都特别熟悉的,但是到底它是什么,用什么来衡量,可能很多人会愣在那里.时间可以见证一切,也可以消磨一切,那些过往的点点滴滴可思可忆.回想往年清明节过后,在家乡的晚上总能 ...

  4. SQLServer学习笔记系列5

    一.写在前面的话 转眼又是一年清明节,话说“清明时节雨纷纷”,武汉的天气伴随着这个清明节下了一场暴雨,整个城市如海一样,朋友圈渗透着清明节武汉看海的节奏.今年又没有回老家祭祖,但是心里依然是怀念着那些 ...

  5. SQLServer学习笔记系列1

    一.前言 一直自己没有学习做笔记的习惯,所以为了加强自己对知识的深入理解,决定将学习笔记写下来,希望向各位大牛们学习交流! 不当之处请斧正!在此感谢!这边就先从学习Sqlserver写起,自己本身对数 ...

  6. SQLServer学习笔记系列4

    一.写在前面的话 好多天没有记录sql学习笔记了,要坚持下去,坚信每一点的进步都是为在积蓄力量.今天看到一幅图,特此分享出来. 通过这幅图,我看到的是每人站在自己的角度看问题,感受是不一样的,就如同学 ...

  7. SQLServer学习笔记系列12

    一.写在前面的话 这个sql学习系列,今天准备告一段落,虽然短短的十几篇文章,深刻感受到将学习的东西记录下来,是需要一种坚持! 这些东西只有反复的学习吸收,最终沉淀下来的才是属于自己的知识.也是提醒自 ...

  8. SQLServer学习笔记系列11

    一.写在前面的话 身体是革命的本钱,这句放在嘴边常说的话,还是拿出来一起共勉,提醒一起奋斗的同僚们,保证睡眠,注意身体!偶尔加个班,也许不曾感觉到身体发出的讯号,长期晚睡真心扛不住!自己也制定计划,敦 ...

  9. SQLServer学习笔记系列8

    一.写在前面的话 最近一直在思考一个问题,什么才能让我们不显得浮躁,真正的静下心来,用心去感受,用心去回答每个人的问题,用心去帮助别人.现实的生活,往往让我们显得精疲力尽,然后我们仔细想过没用,其实支 ...

随机推荐

  1. 如何在Windows中编译Linux Unix的代码(采用cygwin)?

    来源:http://www.cnblogs.com/rocky_yi/archive/2009/12/08/cygwin.html   作者:rocky_y 很多经典算法往往是用C++在linux下实 ...

  2. php下xcache的安装

    下载xcache: wget http://xcache.lighttpd.net/pub/Releases/3.2.0/xcache-3.2.0.tar.gz 安装: tar zxvf xcache ...

  3. dell交换机固件

    Upgrading the S4048-ON Dell Networking OS Image using the Dell Networking OS CLI Bare Metal Provisio ...

  4. Disabling default console handler in Java Logger by codes

    The open source packages usu. relies on log4j or Java Logger to print logs, by default the console h ...

  5. SQL Server认证培训与考试

    Microsoft 技术专员 (MTA) - 数据库 https://www.microsoft.com/zh-cn/learning/mta-certification.aspx MCSA: SQL ...

  6. 介绍Oedis - Redis OH/RM

    作死造轮子 Oedis是近段时间为了解决日志型数据如何与Entity Framework的查询整合的问题写的一个Redis的OH /RM.虽然Redis出来蛮久了,各路高手也都提出了实践方案,但是或许 ...

  7. Ubuntu下安装 jdk6

    Ubuntu下安装 jdk6 罗朝辉 (http://www.cnblogs.com/kesalin/) 本文遵循“署名-非商业用途-保持一致”创作公用协议   1,下载最新的 jdk6 版本,目前最 ...

  8. XP之后Windows的一些变化

    看到很多Windows开发人员,尤其是C++程序员思维还是停留在XP操作系统,当然根据工作是否需要新知识 ,这本身没有错.但是实际上Vista之后的Win7, 再之后的Win8 ,Windows已经发 ...

  9. js模版引擎handlebars.js实用教程——each-循环中使用this

    返回目录 <!DOCTYPE html> <html> <head> <META http-equiv=Content-Type content=" ...

  10. Ember.js实现单页面应用程序

    1.1.1 摘要 单页应用程序 (SPA) 是加载单个HTML 页面并在用户与应用程序交互时动态更新该页面的Web应用程序. SPA使用AJAX和HTML5创建流畅且响应迅速的Web应用程序,不会经常 ...