热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

sqlserver存储过程和触发器

一.存储过程1.存储过程的分类存储过程是一种数据库对象,存储在数据库内,可由应用程序通过一个调用执行,而且允许用户声明变量、有条件执行,具有很强的编程功能存储过程可以分为两类:系统存储过程、用户存储过程和扩展性存储过程1).系统存储过程系

一.存储过程 1.存储过程的分类 存储过程是一种数据库对象,存储在数据库内,可由应用程序通过一个调用执行,而且 允许用户声明变量、有条件执行,具有很强的编程功能 存储过程可以分为两类:系统存储过程、用户存储过程和扩展性存储过程 1).系统存储过程 系

  一.存储过程

  1.存储过程的分类

  存储过程是一种数据库对象,存储在数据库内,可由应用程序通过一个调用执行,而且

  允许用户声明变量、有条件执行,具有很强的编程功能

  存储过程可以分为两类:系统存储过程、用户存储过程和扩展性存储过程

  1).系统存储过程

  系统存储过程是由SQL Server系统提供的存储过程,可以作为命令执行各种操作。

  系统存储过程主要用来从系统表中获取信息,为系统管理员管理SQL Server提供帮助,

  为用户查看数据库对象提供方便。

  系统存储过程定义在系统数据库master中,其前缀是sp_。在调用时不必在存储过程前

  加上数据库名

  2).用户存储过程

  用户存储过程是指用户根据自身需要,为完成某一特定功能,在用户数据库中创建的存

  储过程。

  3).扩展存储过程

  扩展存储过程以在SQL Server环境外执行的动态链接库(DLL,Dynamic-LinkLibrar-ies)

  来实现。扩展存储过程通过前缀“xp_”来标识,它们以与存储过程相似的方式来执行。

  二.触发器

  触发器是当特定事件出现的时候,自动执行或者激活的,与连接到数据库中的用户或者应用程序无关.。一个表最多有三种不同类型的触发器,当UPDATE发生时使用一个触发器;DELETE发生时使用一个触发器;INSERT发生时使用一个触发器

  1.与存储过程的区别

  触发器与存储过程主要的区别在于触发器的运行方式。存储过程必须由用户、应用程序或者触发器来显示式地调用并执行,而触发器是当特定事件出现的时候,自动执行或者激活的,与连接到数据库中的用户或者应用程序无关

  注意: 尽管触发器的功能强大,但是它们也可能对服务器的性能很有害。因此,要注意不要在触发器中放置太多的功能,因为它将降低响应速度,使用户等待的时间增加

  2.触发器的分类

  1). DDL 触发器

  DDL触发器当服务器或者数据库中发生数据定义语言(DDL)事件时将被调用

  2). DML 触发器

  DML触发器是当数据库服务器中发生数据操作语言(DML)事件时要执行的操作

  3.两种特殊的表:DELETED表和INSERTED表

  SQL Server 2008为每个触发器语句都创建了两种特殊的表:DELETED表和INSERTED表。

  这是两个逻辑表,由系统来自创建和维护,,用户不能对他们进行修改。他们存放在内存而不

  是数据库中。这两个表的结构总是与被该触发器作用的表的结构相同。触发器执行完成后,

  与该触发器相关的这两个表也会被删除

  DELETE表存放由执行DELETE或者UPDATE语句而要从表中删除的所有行。在执行DELE

  TE或者UPDATE操作时,被删除的行从触发触发器的表中被移动到DELETE表,这两个表不

  会有共同的行。

  INSERT 表存放由执行INSERET或者UPDATE语句而要向表中插入的所有行。在执行INS

  ERT或者UPDATE事务中,新的行同时添加到触发触发器的表和INSERT表中,INSERT表的内

  容是触发触发器的表中新行的副本。

  注意: 一个UPDATE事务可以看作先执行一个DELETE 操作,再执行一个INSERT操作,旧的行首先被移动到DELETE 表,然后新行同时插入触发触发器的表和INSERT表。

推荐阅读
  • 本文深入探讨网页游戏的开发流程,涵盖从程序框架设计到具体实现的技术细节,旨在为开发者提供全面的指导。 ... [详细]
  • GBase 8s SQL 指南:多列约束详解
    本文档详细介绍了如何在GBase 8s中使用多列约束格式,将其应用于现有表的一列或多列。这种格式类似于CREATE TABLE语句中的多列约束,但提供了一些额外的选项,如INDEX DISABLED关键字。 ... [详细]
  • 本文总结了WebSphere应用服务器出现宕机问题的解决方法,重点讨论了关键参数的调整,包括数据源连接池、线程池设置以及JVM堆大小等,旨在提升系统的稳定性和性能。 ... [详细]
  • 本文探讨了Java编程中MVC模式的优势与局限,以及如何利用Java开发一款基于鸟瞰视角的赛车游戏。 ... [详细]
  • 尽管PHP是一种强大且灵活的Web开发语言,但开发者在使用过程中常会陷入一些典型的陷阱。本文旨在列出PHP开发中最为常见的10种错误,并提供相应的预防建议。 ... [详细]
  • TP-Link无线路由器WPS安全配置指南
    本文详细介绍了如何在TP-Link无线路由器上进行WPS的安全设置,包括关闭不必要的服务、同步主路由器的无线设置等步骤。 ... [详细]
  • 本文深入探讨了JMeter中的参数解析及其线程组插件的应用,重点介绍了聚合报告的各项关键指标,并提供了详细的插件安装步骤。 ... [详细]
  • 本文探讨如何使用 PHP 进行字符串处理,特别是如何检测一个字符串是否存在于另一个字符串中,并确定其具体位置。通过实例代码展示,帮助读者掌握这一常用功能。 ... [详细]
  • 本章深入探讨了现代客户端设计,特别是使用 ASP.NET Core 和 Blazor 构建高效用户界面的方法。 ... [详细]
  • 本文详细介绍了如何在两台运行 Windows Server 2003 的计算机上配置两个 MySQL 实例以实现主从复制。每台计算机分别命名为 Master 和 Slave,确保系统分区及 MySQL 安装路径的正确配置。 ... [详细]
  • 解决ASP.NET Core在IIS中出现的502.5进程失败错误
    本文详细探讨了在Windows Server 2012环境下安装.NET Core后,IIS站点出现502.5错误的原因及解决方案,包括重启服务和系统的方法。 ... [详细]
  • Git支持通过自定义钩子来扩展其功能,这些钩子根据触发条件的不同,可以分为客户端和服务器端两种类型。客户端钩子通常与本地操作相关联,如提交代码或合并分支;而服务器端钩子则与远程仓库的交互有关。 ... [详细]
  • 本文提供了详细的步骤,介绍如何将基于Maven的Java EE项目从Eclipse IDE部署到JBoss应用服务器上。适合初学者和中级开发者参考。 ... [详细]
  • 近期,谷歌公司的一名安全工程师Eduardo Vela在jQuery Mobile框架中发现了一项可能引发跨站脚本攻击(XSS)的安全漏洞。此漏洞使得使用jQuery Mobile的所有网站面临潜在的安全威胁。 ... [详细]
  • 探讨GET与POST请求数据传输的最大容量
    在Web开发领域,GET和POST是最常见的两种数据传输方法。本文将深入探讨这两种请求方式在不同环境下的数据传输能力及其限制。 ... [详细]
author-avatar
longyuyuyu
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有