SQL Server数据库(SQL Sever语言 存储过程及触发器)

存储过程:就像函数一样的
会保存在数据库中--》可编程性--》存储过程

创建存储过程: 保存在数据库表,可编程性,存储过程
create proc jiafa

--需要的参数
@a int,
@b int
as
--存储过程内容
declare @c int;
set @c [email protected] + @b;
return @c;
go

相当于一个函数
public int 函数名 (变量1,变量2)
{
函数语句
return int c
}

存储之后可以直接调用,
执行存储过程
exec 存储名

有返回值时
declare @f int;
exec @f= jiafa 3,5;
print @f;

--例:在CAR表中查询对应种类的车辆数目
--存储过程
creat proc ChaXun
@n varchar(20)
as
declare @num int
select @num=coount(*) from car where name like ‘%‘[email protected]+‘%‘
go

--调用方法
declare @m int
exec @m=ChaXun ‘奥迪‘
print @m

触发器:
是一个特殊的存储过程;
通过增删改查的动作来触发执行,没有参数,没有返回值;
存储位置在要执行的表的下拉列表中

不去触发不执行,满足条件之后执行,相当于HTML中的事件

create trigger 触发器名称

Insert_Student --命名规范 动作_要执行的表名 为了以后更容易的了解触发器要使用的情况

on Student --针对于那张表
for insert --针对于那个动作来触发

--onclick= "show()"
as
触发器要执行的代码

go

1、for的意思是在动作执行之后触发
2、instead of delete 的意思是删除之前的引发,可以理解为替代,写了这个之后写的性代码就没有用了,就被触发器的代码覆盖了

删除存在外键的表的内容时,需要先删除外键连接的表的内容
create trigger Delete_info
on inf0
instead of delete
as
declare @c varchar(20)
select @c =Code from deleted

delete from work where [email protected]
delete from family where [email protected]
delete from info where [email protected]

go

instead of的使用比for的频繁

面试过程中问的比较多,但实际工作是用的比较少

时间: 2024-12-20 19:40:44

SQL Server数据库(SQL Sever语言 存储过程及触发器)的相关文章

查询MS SQL Server数据库死锁的一个存储过程

查询Sqlserver数据库死锁的一个存储过程 使用sqlserver作为数据库的应用系统,都避免不了有时候会产生死锁.死锁出现以后,维护人员或者开发人员大多只会通过sp_who来查找死锁的进程,然后用sp_kill杀掉. 利用sp_who_lock这个存储过程,可以很方便的知道哪个进程出现了死锁,出现死锁的问题在哪里. --创建或修改sp_who_lock存储过程 CREATE procedure sp_who_lock --ALTER procedure sp_who_lock as beg

SQL Server CLR 使用 C# 自定义存储过程和触发器

这一篇博客接着上一篇博客继续介绍 SQL CLR Stored Procedure 和 CLR Trigger, 上一篇博客介绍了 SQL CLR Function 的使用,以及 CLR 程序集的注册和 CLR Function 的注册. 我的上一篇博客:SQL Server CLR 使用 C# 自定义函数 四.CLR Stored Procedure 接下来在之前的项目选择添加新项,选择 SQL CLR C# 存储过程. public partial class StoredProcedure

SQL Sever语言 存储过程及触发器

存储过程:就像函数一样的会保存在数据库中-->可编程性-->存储过程 创建存储过程: 保存在数据库表,可编程性,存储过程create proc jiafa --需要的参数@a int,@b intas--存储过程内容declare @c int;set @c [email protected] + @b; return @c;go 相当于一个函数public int 函数名 (变量1,变量2){函数语句return int c} 存储之后可以直接调用,执行存储过程exec 存储名 有返回值时d

SQL server数据库之存储过程

在说存储过程之前我们先说一下SQL server数据库的一些基本语法 -- 0. Sql server中的代码块 /* 类似于各种开发语言,sql server也具有代码块的分割,大部分语言代码块用大括号分割({})*/ begin end --用于sql server数据库中的代码分割 -- 一. 变量的定义.赋值.输出 declare @a int--定义变量 set @a=5 --变量赋值 print @a --打印变量的值 --使用select语句赋值 --select既可以用于变量赋值

SQL Server数据库存储过程中拼接字符串注意的问题

在SQL Server数据库中书写复杂的存储过程时,一般的做法是拼接字符串,最后使用EXEC sp_executesql '拼接的字符串' 查询出结果. 先看一段代码: 1 -- ============================================= 2 -- Author: XXX 3 -- Create date: 2014-09-19 4 -- Description: 获取学生列表信息 5 -- ====================================

利用存储过程来重命名SQL Server数据库

最近遇到一个需要在多用户模式下重新命名数据库的Case, 因为数据库可能被其他用户使用,所以直接修改可能会失败.对于此种情况,我们可以等所有用户结束使用数据库时修改,或者是将数据库切换到单用户模式下进行操作. 有时候,我们在开发过程中需要直接把生产环境的数据库拿到开发环境来测试开发.我们可以直接重命名生产环境上的数据库.这样以来,即使你有些SQL没有保存,也可以直接从原来的数据库中抓取. 有两个重要的细节我们必须注意 当重名名数据库时, filegroup的名字和数据文件名(.mdf,.ldf)

C#与sql server数据库存储过程的操作实例

通过这几天的学习和实际操作,把C#与sql server数据库存储过程的操作搞清楚了. using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Data.SqlClient; using System.Drawing; using System.Linq; using System.Text; using System.Windows.

50种方法优化SQL Server数据库查询(转载)

原文地址:http://www.cnblogs.com/zhycyq/articles/2636748.html 查询速度慢的原因很多,常见如下几种: 1.没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷) 2.I/O吞吐量小,形成了瓶颈效应. 3.没有创建计算列导致查询不优化. 4.内存不足 5.网络速度慢 6.查询出的数据量过大(可以采用多次查询,其他的方法降低数据量) 7.锁或者死锁(这也是查询慢最常见的问题,是程序设计的缺陷) 8.sp_lock,sp_who,活动的用

提高SQL Server数据库效率常用方法

1.没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷) 2.I/O吞吐量小,形成了瓶颈效应. 3.没有创建计算列导致查询不优化. 4.内存不足 5.网络速度慢 6.查询出的数据量过大(可以采用多次查询,其他的方法降低数据量) 7.锁或者死锁(这也是查询慢最常见的问题,是程序设计的缺陷) 8.sp_lock,sp_who,活动的用户查看,原因是读写竞争资源. 9.返回了不必要的行和列 10.查询语句不好,没有优化 ●可以通过如下方法来优化查询 : 1.把数据.日志.索引放到不同的