time 
设为首页】【收藏本站
当前位置: 主页 > 数据库 > SQL Server > SQL 基础 > SQL基础总结(二)锁、游标、索引

SQL基础总结(二)锁、游标、索引

时间:2013-10-14 13:50 点击:1465次 字体:[ ]




  锁的模式

锁模式

描述

共享(S)

用于不更改或不更新数据(只读操作),如SELECT语句

更新(U)

用于可更新的资源中。防止当多个会话在读取、锁定以及随后可能进行的资源更新时发生常见形式的死锁。

排它(X)

用于数据修改操作,例如INSERT、UPDATE或DELETE。确保不会同时对同一资源进行多重更新

意向

SQL Server有在资源的低层获得共享锁或排它锁的意向意向锁的类型为:意向共享(IS)、意向排它(IX)以及意向排它共享(SIX)

架构

在执行依赖于表架构的操作时使用。架构锁的类型为:架构修改(Sch-M)和架构稳定(Sch-S)

大容量更新(BU)

向表中大容量复制数据并指定了TABLOCK提示时使用

    死锁 死锁是指在一组进程中的各个进程均占有不会释放的资源,但因互相申请被其他进程所站用不会释放的资源而处于的一种永久等待状态。

  死锁的四个必要条件

    互斥条件(Mutual exclusion):资源不能被共享,只能由一个进程使用。
    请求与保持条件(Hold and wait):已经得到资源的进程可以再次申请新的资源。
    非剥夺条件(No pre-emption):已经分配的资源不能从相应的进程中被强制地剥夺。
    循环等待条件(Circular wait):系统中若干进程组成环路,该环路中每个进程都在等待相邻进程正占用的资源

  死锁的处理方法

    查看那个spid处于wait状态,然后用kill spid来干掉(即破坏死锁的第四个必要条件:循环等待)。
    使用SET LOCK_TIMEOUT timeout_period(单位为毫秒)来设定锁请求超时。默认情况下,数据库没有超时期限(timeout_period值为-1,可以用SELECT @@LOCK_TIMEOUT来查看该值,即无限期等待)。
    SQL Server内部有一个锁监视器线程执行死锁检查,锁监视器对特定线程启动死锁搜索,检测到死锁后,数据库引擎选择运行回滚开销最小的事务的会话作为死锁牺牲品回滚死锁牺牲品的事务并释放该事务持有的所有锁,使其他线程的事务可以请求资源并继续运行。  

 

游标

  游标定义:

    可以对一个select的结果集进行处理,或是不需要全部处理,就会返回一个对记录集进行处理之后的结果。

    游标实际上是一种能从多条数据记录的结果集中每次提取一条记录的机制。游标可以完成:

    # 允许定位到结果集中的特定行

    # 从结果集的当前位置检索一行或多行数据

    # 支持对结果集中当前位置的进行修改

    由于游标是将记录集进行一条条的操作,所以这样给服务器增加负担,一般在操作复杂的结果集的情况下,才使用游标。SQL Server 2005有三种游标:T-SQL游标、API游标、客户端游标。

  游标的基本操作

    游标的基本操作有定义游标、打开游标、循环读取游标、关闭游标、删除游标。

  A、 定义游标

  1. declare cursor_name    --游标名称  
  2. cursor [local | global]    --全局、局部  
  3. [forward only | scroll]    --游标滚动方式  
  4. [read_only | scroll_locks | optimistic]    --读取方式  
  5. for select_statements                    --查询语句  
  6. [for update | of column_name ...]        --修改字段  

 

  参数:

    forward only | scroll:前一个参数,游标只能向后移动;后一个参数,游标可以随意移动

    read_only:只读游标

    scroll_locks:游标锁定,游标在读取时,数据库会将该记录锁定,以便游标完成对记录的操作

    optimistic:该参数不会锁定游标;此时,如果记录被读入游标后,对游标进行更新或删除不会超过

  B、 打开游标

    open cursor_name;

    游标打开后,可以使用全局变量@@cursor_rows显示读取记录条数

  C、 检索游标

fetch cursor_name;

检索方式如下:

fetch first; 读取第一行

fetch next; 读取下一行

fetch prior; 读取上一行

fetch last; 读取最后一行

fetch absolute n; 读取某一行

如果n为正整数,则读取第n条记录

如果n为负数,则倒数提取第n条记录

如果n为,则不读取任何记录

fetch pelative n

如果n为正整数,则读取上次读取记录之后第n条记录

如果n为负数,则读取上次读取记录之前第n条记录

如果n为,则读取上次读取的记录

  D、 关闭游标

    close cursor_name;

  E、 删除游标

    deallocate cursor_name;

  游标操作示例

  1. --创建一个游标  
  2. declare cursor_stu cursor scroll for 
  3.     select id, name, age from student;  
  4. --打开游标  
  5. open cursor_stu;  
  6. --存储读取的值  
  7. declare @id int,  
  8.         @name nvarchar(20),  
  9.         @age varchar(20);  
  10. --读取第一条记录  
  11. fetch first from cursor_stu into @id, @name, @age;  
  12. --循环读取游标记录  
  13. print '读取的数据如下:';  
  14. --全局变量  
  15. while (@@fetch_status = 0)  
  16. begin 
  17.     print '编号:' + convert(char(5), @id) + ', 名称:' + @name + ', 类型:' + @age;  
  18.     --继续读取下一条记录  
  19.     fetch next from cursor_stu into @id, @name, @age;  
  20. end 
  21. --关闭游标  
  22. close area_cursor;  
  23.  
  24. --删除游标  
  25. --deallocate area_cursor;  



本文地址 : http://www.fengfly.com/plus/view-213920-1.html
标签: 索引 SQL 游标
------分隔线----------------------------
最新评论 查看所有评论
发表评论 查看所有评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
验证码: