iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >数据库中的触发器,索引 ,事务
  • 182
分享到

数据库中的触发器,索引 ,事务

2024-04-02 19:04:59 182人浏览 八月长安
摘要

一.触发器 触发器是一种实施复杂数据完整性的特殊存储过程,在对表或视图执行update、insert或delete语句时自动触发执行,以防止对数据进行不正确、未授权或不一致的参数。 creat&n

一.触发器

 触发器是一种实施复杂数据完整性的特殊存储过程,在对表或视图执行update、insert或delete语句时自动触发执行,以防止对数据进行不正确、未授权或不一致的参数。


creat [temp|temporary] trigger name
[before|after] [insert|update|delete of columns] on table
begin
sql语句
end;

  触发器能够维持两个表间的参照完整性,就像外键一样。外键执行这个任务的效率更高,因为它们在数据改变之前被测试,而不像触发器在数据改变后才触发。


二.索引

(1)定义:

  1. 索引是数据库的对象之一,索引是为了加速对表中数据行的检索而创建的一种分散的一种存储结构。

    索引是针对一个表而建立的,它是由数据页面以外的索引页面组成的 

create unique clustered index book_id_index--惟一性聚簇索引
on book(book_id asc)
with 
fillfactor=50 


(2)索引的分类

  1. 聚簇索引

    数据表的物理顺序和索引表的顺序相同,它根据表中的一列或多列值的组合排列记录

create unique clustered index book_id_index--惟一性聚簇索引
on book(book_id asc)
with 
fillfactor=50 

b. 非聚簇索引

create nonclustered index student_course_index
on student_course(student_id asc,course_id asc)
with 
fillfactor=50

三.事务

(1)定义:

  事务是指一个操作序列,这些操作序列要么都被执行,要么都不被执行,它是一个不可分割的工作单元。

(2)语法步骤:

  1. 事务开始:BEGIN TRANSACTio

  2. 事务提交:COMMIT TRANSACTION 

  3. 事务回滚:ROLLBACK TRANSACTION 

  4. 判断某条语句执行是否出错:全局变量@@ERROR; 

    @@ERROR只能判断当前一条T-SQL语句执行是否有错,为了判断事务中所有T-SQL语句是否有错,我们需要对错误进行累计; 例:SET @errorSum=@errorSum+@@error


四.存储过程

(1)定义:

  存储过程是一系列预先编辑好的、能实现特定数据操作功能的SQL代码集。它与特定的数据库相关联,存储在SQL Server 服务器上。

(2)存储过程的好处:

  1. 重复使用。存储过程可以重复使用,从而减少数据库开发人员的工作量

  2. 提高性能。存储过程在创建的时候就进行了编译,将来使用的时候就不用再编译。一般的SQL语句使用一次就编译一次,所以使用存储过程提高了效率

  3. 减少网络流量。存储过程位于服务器上,调用的时候只需要传递存储过程的名称以及参数就可以了,因此减低了网络传输的运输量

  4. 安全性。参数化的存储过程可以防止SQL注入***,而且可以将Grant、Deny、以及Revoke权限应用于存储过程

  定义一个存储过程:

create proc spAddStudents
  @name  nvarchar(50)=null
  as
  begin transaction --事务
  insert into [StudentInfo].[dbo].[Students]
  (Name)
  values
  (@name)
  if @@ERROR<>0
  begin
  rollback tran
  return
  end

创建一个实现加法计算并将运算结果作为输出参数的存储过程

 create proc spAdd
  @value1 int,
  @value2 int,
  @result int output
  as
  select @result=@value1+@value2
  Go

执行spAdd存储过程

declare @value1 int
  declare @value2 int
  declare @result int
  set @value1=1
  set @value2=1
  exec spAdd @value1,@value2,@result output
  print convert(char(5),@value1) +'+'+convert(char(5),@value2) +'='+ convert(char(5),@result)

参考:Http://www.xuebuyuan.com/2041347.html

您可能感兴趣的文档:

--结束END--

本文标题: 数据库中的触发器,索引 ,事务

本文链接: https://www.lsjlt.com/news/37253.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL数据库的触发器和事务
    目录一、触发器概念二、 触发器的操作触发器的增删改操作触发器的查看删除操作三、事务概念四、事务的操作基本流程基础操作事务的提交方式事务的隔离级别隔离操作一、触发器 概念 触发器是SQ...
    99+
    2022-11-13
    MySQL数据库触发器 MySQL数据库事务
  • mysql中索引,触发器,事务,存储引擎的理解
    1、索引:作用于表中的某列,并将其进行排序,有助于快速地进行查询。   索引是对数据库表中一个或多个列的值进行排序的数据结构,是用于提高在数据库表中访问数据的速度的数据库对象。...
    99+
    2024-04-02
  • MySQL数据库索引和事务
    目录1. 索引 1.1 概念 1.2 作用 1.3 索引的原理 1.3.1 减少磁盘的访问次数是构建索引的核心思想 1.3.2 B+ 树适用实现索引的底层 1.4 适用场景 1.5 ...
    99+
    2024-04-02
  • 数据库-触发器
    目录 1. 触发器概述 2. 触发器的创建 2.1 创建触发器语法 3. 查看、删除触发器  3.2 删除触发器 4. 触发器的优缺点 4.2 缺点 4.3 注意点 在实际开发中,我们经常会遇到这样的情况:有 2 个或者多个相互关联的表...
    99+
    2023-09-22
    数据库 mysql
  • MySQL数据库的事务和索引详解
    目录一、事务:事务四大特性:并发事务带来哪些问题?(隔离所导致的一些问题)事务隔离级别有哪些?MySQL的默认隔离级别:二、索引:索引的作用:索引的分类:索引准则:索引的数据结构:总...
    99+
    2024-04-02
  • 数据库中的索引
    目录 一、什么是索引? 索引的实现原理 什么时候考虑添加索引? 索引的类型 二、为什么要有索引? 三、怎么用索引? 索引的创建和删除 怎么查看一条sql语句中使用了索引? 索引失效的情况以及对应解决方案 一、什么是索引? 索引是数据...
    99+
    2023-09-02
    mysql
  • 数据库触发器的作用
    这篇文章主要介绍数据库触发器的作用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!数据库中的触发器的作用:触发器主要用于强制复杂的业务规则和要求,还有助于强制引用的完整性,便于在添加,...
    99+
    2024-04-02
  • 关于数据库“事务”“索引”“实例”的含义
    在学习数据库的时候经常听见“事务”“索引”“实例”等术语,那么他们具体是什么意思呢?事务  事务:是指一个完整的操作过程。在这个过程中任何一个环节出现“意外”,那么这个操作过程将会被回滚。事务经常...
    99+
    2024-04-02
  • 数据库中触发器有什么用
    这篇文章主要介绍了数据库中触发器有什么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。触发器有两个稳态,可分别表示二进制数码0和1,无外触发...
    99+
    2024-04-02
  • 数据库中触发器trigger怎么用
    这篇文章主要介绍了数据库中触发器trigger怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 实验如下:-...
    99+
    2024-04-02
  • 揭开数据库触发器的神秘面纱:深入探索触发器的运作机制
    数据库触发器概述 数据库触发器是一种特殊的数据库对象,它可以自动执行某些预定义的操作,对数据库中数据的改变做出相应反应。触发器主要用于确保数据库数据的完整性和一致性,并简化某些任务的执行。触发器与存储过程类似,都是由一组 SQL 语句组...
    99+
    2024-02-08
    数据库触发器 触发器类型 触发器语法 触发器示例 触发器应用
  • MySQL数据库索引和事务的作用是什么
    本篇内容主要讲解“MySQL数据库索引和事务的作用是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL数据库索引和事务的作用是什么”吧!1. 索引1.1 概念索引是为了加速对表中数据行...
    99+
    2023-06-22
  • oracle数据库触发器在哪
    oracle 数据库中的触发器位于数据字典中,具体位置是在 user_triggers 表中。访问方法包括查询特定表的触发器或查询所有表的触发器。user_triggers 表包含有关触...
    99+
    2024-04-08
    oracle
  • SQL Server如何查询数据库所有存储过程、触发器、索引信息
    这篇文章主要介绍SQL Server如何查询数据库所有存储过程、触发器、索引信息,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 1. 查询所有存储过程select...
    99+
    2024-04-02
  • AndoridSQLite数据库开发中如何添加索引
    本篇文章为大家展示了AndoridSQLite数据库开发中如何添加索引,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。AndoridSQLite数据库开发添加索引索引是一种通过预先排序和对表的一个或多...
    99+
    2023-06-04
  • 查看数据库中存在触发器的表
    这次在项目中,我们为了做数据库同步,采用了触发器机制,为数据库做迁移时,我们需要获取数据库中那些表使用了触发器,方便制作数据库安装包。 构思: 触发器在MSSQL作为一个对象进行管理,那么我们就可以通过s...
    99+
    2024-04-02
  • MySQL数据库中的unique索引:用法与注意事项
    MySQL数据库中的unique索引:用法与注意事项 MySQL是一种非常流行的开源关系型数据库管理系统,可以用于存储和管理大量的数据。在MySQL中,我们经常会使用索引来提高数据的检...
    99+
    2024-03-15
    mysql 索引 unique
  • 数据库中索引的实现原理:B-tree索引
    数据库会使用一些方式来存储、读取和修改数据,在实际的数据库管理中,数据库会同时使用B-tree和B+tree来存储数据。其中B-tree用于索引,B+tree用于存储实际记录。本文带来B-tree在数据库中的索引机制。 B-t...
    99+
    2024-01-22
    B树的概念
  • 如何在MySQL元数据库里查看索引,约束,触发器,存储过程和事件的相关信息
    -- 查看主键约束 SELECT * FROM information_schema.`TABLE_CONSTRAINTS`; -- 查看外键约束 SELECT * FROM inf...
    99+
    2024-04-02
  • SQL Server数据库中有哪些触发器
    这篇文章将为大家详细讲解有关SQL Server数据库中有哪些触发器,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、触发器的优点1. 触发器是自动的。当对...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作