教学文库网 - 权威文档分享云平台
您的当前位置:首页 > 文库大全 > 教育文库 >

高性能的数据库--编程细节

来源:网络收集 时间:2025-09-11
导读: 高性能的数据库--编程细节 高性能的数据库--编程细节(1) 1、触发器 2、游标 3、函数 4、存储过程 5、事务 这里只打算讲解四部分了,也就最简单、最常用的四部分。 1、触发器。 定义: 何为触发器?在SQL Server里面也就是对某一个表的一定的操作,触发某种

高性能的数据库--编程细节

高性能的数据库--编程细节(1)


 1、触发器
 2、游标
 3、函数
 4、存储过程
 5、事务


这里只打算讲解四部分了,也就最简单、最常用的四部分。

 1、触发器。

   定义: 何为触发器?在SQL Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是一个特殊的存储过程。
   常见的触发器有三种:分别应用于Insert , Update , Delete 事件。(SQL Server 2000定义了新的触发器,这里不提)

   我为什么要使用触发器?比如,这么两个表:

   Create Table Student(       --学生表
    StudentID int primary key,   --学号
    ....
   )

   Create Table BorrowRecord(       --学生借书记录表
    BorrowRecord int identity(1,1),   --流水号 
    StudentID   int ,          --学号
    BorrowDate  datetime,        --借出时间
    ReturnDAte  Datetime,        --归还时间
    ...
   )

  用到的功能有:
    1.如果我更改了学生的学号,我希望他的借书记录仍然与这个学生相关(也就是同时更改借书记录表的学号);
    2.如果该学生已经毕业,我希望删除他的学号的同时,也删除它的借书记录。
  等等。

  这时候可以用到触发器。对于1,创建一个Update触发器:

  Create Trigger truStudent
   On Student
   for Update
  -------------------------------------------------------
  --Name:truStudent
  --func:更新BorrowRecord 的StudentID,与Student同步。
  --Use :None
  --User:System
  --Author: 懒虫 # SapphireStudio (http://doc.guandang.net)
  --Date : 2003-4-16
  --Memo : 临时写写的,给大家作个Sample。没有调试阿。
  -------------------------------------------------------
  As
   if Update(StudentID)
   begin

    Update BorrowRecord
     Set br.StudentID=i.StudentID
     From BorrowRecord br , Deleted d ,Inserted i
     Where br.StudentID=d.StudentID

   end   
        
  理解触发器里面的两个临时的表:Deleted , Inserted 。注意Deleted 与Inserted分别表示触发事件的表“旧的一条记录”和“新的一条记录”。
  一个Update 的过程可以看作为:生成新的记录到Inserted表,复制旧的记录到Deleted表,然后删除Student记录并写入新纪录。

  对于2,创建一个Delete触发器
 
 Create trigger trdStudent
   On Student
   for Delete
  -------------------------------------------------------
  --Name:trdStudent
 

高性能的数据库--编程细节

 --func:同时删除 BorrowRecord 的数据
  --Use :None
  --User:System
  --Author: 懒虫 # SapphireStudio (http://doc.guandang.net)
  --Date : 2003-4-16
  --Memo : 临时写写的,给大家作个Sample。没有调试阿。
  -------------------------------------------------------
  As
   Delete BorrowRecord
    From BorrowRecord br , Delted d
    Where br.StudentID=d.StudentID

  从这两个例子我们可以看到了触发器的关键:A.2个临时的表;B.触发机制。
  这里我们只讲解最简单的触发器。复杂的容后说明。
  事实上,我不鼓励使用触发器。触发器的初始设计思想,已经被“级联”所替代。


 2.游标
 
  在SQL 2000之前,游标可谓是SQL Server心中的痛: 老牛般的速度(CPU),河马般的胃口(内存)。可你却不能不用他。
  什么叫游标呢?说白了就是像高级语言一样,是存放数据集,并逐条访问的一种机制。
  比如在Delphi里面,要实现类似于这样的功能:(呵呵,不好意思,我只会Delphi,所以只能举一个Delphi的例子)
 
  //这是一段Delphi的源代码
  adoDataSet1.Close;
  http://doc.guandang.netmandText:=' Select * From Student order by StudentID ';
  adoDataSet1.Open;
  While Not adoDAtaSet1.Eof Do
  Begin
  
   YourVar:=adoDAtaSet1.FieldByName('StudentID').AsInteger;
   DoSomeThing();
   .... 
   adoDataSet1.Next;
  End
  
  在SQL Server 并没有很好的数据逐条访问机制,如果有,那就是游标。

  还是举例子:

  对于表

   Create Table BorrowRecord(       --学生借书记录表
    BorrowRecord int identity(1,1),   --流水号 
    StudentID   int ,          --学号
    StudentFeeID int ,          --费用结算号  (外键)
    BorrowDate  datetime,        --借出时间
    ReturnDAte  Datetime,        --归还时间
    Fee      Money          --借书费用
    ...
   )

   Create Table StudentFee(        --学生费用结算表
    StudentFeeID int primarykey ,    --费用结算号  (主键)
    StudentID int ,            --学号
    BorrowBookAllFee      Money,   --所有借书总费用 
    ...
   )

   两者关系为多对一的关系,关联字段为StudentFeeID

 
  由于某种原因StudentFee表的数据遭到了破坏,我想StudentFee循环一遍将“所有借书总费用”重算 。

  -----------------------------------------------------------------------
  ---

高性能的数据库--编程细节

----------------------------------------------------
  --Name:一部分代码
  --func:更新学生借书总费用
  --Use :
  --User:
  --Author: 懒虫 # SapphireStudio (http://doc.guandang.net)
  --Date : 2003-4-16
  --Memo : 临时写写的,给大家作个Sample。没有调试阿。
  -------------------------------------------------------

   --声明一个游标
   Declare curStudentFee Cursor
    for
    Select StudentFeeID From StudentFee    …… 此处隐藏:8631字,全部文档内容请下载后查看。喜欢就下载吧 ……

高性能的数据库--编程细节.doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.jiaowen.net/wenku/1813732.html(转载请注明文章来源)
Copyright © 2020-2025 教文网 版权所有
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:78024566 邮箱:78024566@qq.com
苏ICP备19068818号-2
Top
× 游客快捷下载通道(下载后可以自由复制和排版)
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
注:下载文档有可能出现无法下载或内容有问题,请联系客服协助您处理。
× 常见问题(客服时间:周一到周五 9:30-18:00)