SQL存储过程使用参考代码

存储过程   use EBuy go  --常用的系统存储过程  sp_addmessage  --将新的用户定义错误消息存储在SQL Server数据库实例中  sp_helptext  --显示用户定义的规则、默认值、存储过程、函数、视图等对象的实际文本  sp_xml_preparedocument  --读取作为输入提供的XML文本,然后使用MSXML分析器对其进行分析,并提供分析后的文档供使用  sp_helpdb ‘EBuy‘  --查看指定数据库的信息 sp_databases  --列出服务器上的所有数据库  sp_server_info  --列出服务器信息,如字符集、版本和排列顺序等 sp_stored_procedures  --列出当前环境中的所有存储过程 sp_configure  --修改SQL Server全局配置选项 sp_adduser --向当前数据库中添加新的用户  sp_addrole  --在当前数据库中创建新的数据库角色    --用户自定义存储过程 create table users(  id int primary key,  name varchar(20) not null,   pwd varchar(20) not null )  insert into users values(1,‘zhangsan‘,‘zhang01‘) go   create procedure addUser  --创建存储过程(procedure可以简写为proc)  @id int,  @name varchar(20),  @pwd varchar(20) as   begin   insert into users(id,name,pwd) values(@id,@name,@pwd)  end   exec addUser 2,‘lisi‘,‘lisi01‘  --执行存储过程(实参传递的顺序和所对应的形参顺序必须一致)   exec addUser @name=‘wangwu‘,@pwd=‘wang01‘,@id=3  --执行存储过程,这种方式顺序可以不一致   declare @v_id int,@v_name varchar(20),@v_pwd varchar(20)  set @v_id=5  set @v_name=‘zhaoliu2‘  set @v_pwd=‘zhao022‘  exec addUser @v_id,@v_name,@v_pwd  --执行存储过程,调用存储过程并传递变量参数(顺序必须与定义变量的顺序一致)   select * from users

2  --制定默认值 use Study  if exists(select * from sys.all_objects where name=‘increaseCredit‘ and type=‘P‘)  drop procedure increaseCredit go   create proc increaseCredit  @stuName char(6)=null,  --指定null为默认值  @credit int = 3  --制定整数值3为默认值 as  begin   if @stuName=null    begin     print ‘没有指定学号,更新无法完成‘     return    end  update student set [email protected] where [email protected]  end   exec increaseCredit ‘程琳‘,5  --提供所有参数  exec increaseCredit ‘程琳‘  --提供部分参数,则第二个参数使用默认值3    --指定参数方向  if exists(select name from sys.all_objects where name=‘avgCreditForMajor‘ and type=‘P‘)  drop proc avgCreditForMajor   create proc avgCreditForMajor  @majorId int,  --输入参数  @avg decimal(4,1) output  --输出参数 as  select @avg=avg(credit) from student where [email protected] go   declare @avgCredit decimal(4,1)    exec avgCreditForMajor 1,@avgCredit output  --将输出的返回值保存在@avgCredit变量中,注意输出参数也必须指定output关键字  print(‘专业平均学分:‘+cast(@avgCredit as varchar))  --显示储存过程的返回值 go   --使用return语句 use EBuy  if exists(select name from sys.all_objects where name=‘checkCity‘ and type=‘P‘)  drop proc avgCreditForMajor   create proc checkCity  @cusid varchar(20) as  if(select address from customer where [email protected]) like ‘%上海%‘   return 1  else if(select address from customer where [email protected]) not like ‘%上海%‘

3    return 2  else    return 3   declare @ret_status int  exec @ret_status=checkCity ‘1001‘  --客户住在上海 select @ret_status as ‘返回状态‘   declare @ret_status int  exec @ret_status=checkCity ‘1004‘  --客户不住在上海 select @ret_status as ‘返回状态‘   declare @ret_status int  exec @ret_status=checkCity ‘13204‘  --客户不存在的情况 select @ret_status as ‘返回状态‘   --事物和错误处理 create proc procTest as  declare @num int  select @num=9  begin try   while @num>0   begin    print convert(varchar,sqrt(@num))    select @[email protected]    if @num=5     raiserror(‘基数已小于6‘,16,1)   end  end try  begin catch   print ‘放生错误的是:‘+convert(varchar,error_procedure())   print ‘错误编号:‘+convert(varchar,error_number())   print ‘错误描述:‘+convert(varchar,error_message())   print ‘错误级别:‘+convert(varchar,error_severity())   print ‘错误位于:‘+convert(varchar,error_line())   print ‘错误状态:‘+convert(varchar,error_state())  end catch go   exec procTest  --执行存储过程     --存储过程中的事务 use EBuy  create table account(  accId int,  type varchar(10),  balance decimal(10,2) )

4  insert into account values(33,‘savings‘,3000) insert into account values(33,‘checking‘,1500)   if exists(select name from sys.all_objects where name=‘savingsToChecking‘ and type=‘P‘)  drop proc savingsToChecking go  create proc savingsToChecking  @accid int,  @num decimal(10,2) as  declare @bal decimal(10,2)  begin try   select @bal=balance from account where [email protected] and type=‘savings‘   if @num>@bal    return 1   begin tran    update account set [email protected] where [email protected] and type=‘savings‘    update account set [email protected] where [email protected] and type=‘checking‘   commit tran   return 0  end try  begin catch   rollback tran   return 2  end catch go   declare @retCode int begin  exec @retCode=savingsToChecking 33,1500  if @retCode=0   print ‘转账成功‘  else if @retCode=1   print ‘转账金额大于账面余额,转账失败‘  else    print ‘数据库发生错误,转账失败‘ end    --存储过程的查看、修改和删除  sp_helptext ‘savingsToChecking‘  --查看存储过程   alter proc savingsToChecking  @accid int,  --此处可以修改参数的定义  @num decimal(10,2)   drop proc savingsToChecking  --删除存储过程    --重新编译存储过程 --1

5  sp_recompile savingsToChecking  --2  create proc savingsToChecking  @accid int,  @num decimal(10,2)  with recompile   --创建存储过程的时候指定 as ......   --3  exec savingsToChecking 33,1500 with recompile

时间: 2024-08-07 21:20:42

SQL存储过程使用参考代码的相关文章

《软件测试自动化之道》读书笔记 之 SQL 存储过程测试

<软件测试自动化之道>读书笔记 之 SQL 存储过程测试 2014-09-28 待测程序测试程序   创建测试用例以及测试结果存储  执行T-SQL脚本  使用BCP工具导入测试用例数据  创建T-SQL 测试套件  当待测存储过程返回行集的时候,如何判断测试结果是否通过  当待测存储过程返回out参数时,如何判断测试结果是否通过  当待测存储过程没有返回值时,如何判断测试结果是否通过 许多基于Windows的系统都使用了SQL Server作为后台组件.待测程序经常通过存储过程来访问数据库.

PL/SQL存储过程编程

/**author huangchaobiao *Email:[email protected] */ PL/SQL存储过程编程(上) 1. Oracle应用编辑方法概览 答:1) Pro*C/C++/... : C语言和数据库打交道的方法,比OCI更常用; 2) ODBC 3) OCI: C语言和数据库打交道的方法,和ProC很相似,更底层,很少用; 4) SQLJ: 很新的一种用Java访问Oracle数据库的方法,会的人不多; 5) JDBC 6) PL/SQL: 存储在数据内运行, 其他

SQL存储过程

1.认识存储过程 学完菜鸟上的SQL操作后打算好好深入下索引,然而学习过程中实际操作好多都是存储过程,所以只能先掌握存储过程再去深入索引了.使用存储过程有3个优点:存储过程是一个编译过的代码块,因此执行效率比t-sql高:使用存储过程可以不要写大量的t-sql语句,提高通信速率:通过存储过程能够使没有权限的用户在控制之下间接地存取数据库,保证数据的安全性.在SQL中存储过程分为系统存储过程和用户自定义存储过程,系统存储过程主要是以sp_为前缀的,下面是常用的系统存储过程,在我的sql里测试成功.

sql存储过程和事务的应用

在去年,学习数据库的时候就学过存储过程了.一直都只知道一些理论,却不知道如何去使用.时隔一年,终于找到如何使用存储过程了. 在机房收费系统中,有些操作,需要多次执行sql语句,多次执行完成才算是完成这个事件流.但是如果其中有一个环节出了错误,那么没出错误的那些操作是不是就多余了. 执行存储过程,就是执行多句SQl语句.而事务,是为了控制这些语句 要么都做,要么 都不做. 在机房收费系统中,执行sql语句的时候. 一般的sql语句使用方法:定义一个字符串,用于存放sql语句.之后指明command

C#调用 Oracle 存储过程样例代码

-- 建表CREATE TABLE sale_report (     sale_date DATE NOT NULL ,     sale_item VARCHAR(2) NOT NULL ,      sale_money DECIMAL(10,2) NOT NULL,      PRIMARY KEY(sale_date, sale_item)); -- 測试数据DECLAREv_begin_day DATE;v_end_day DATE;BEGIN v_begin_day := TO_D

SQL Server2008宝典 全书代码

3.3.7 -- ============================================= -- Create database template -- ============================================= USE master GO -- Drop the database if it already exists IF EXISTS ( SELECT name FROM sys.databases WHERE name = N'test

SQL存储过程实例详解

SQL存储过程实例详解 本文用3个题目,从建立数据库到创建存储过程,详细讲解数据库的功能. 题目1 学校图书馆借书信息管理系统建立三个表: 学生信息表:student 字段名称 数据类型 说明 stuID char(10) 学生编号,主键 stuName Varchar(10) 学生名称 major Varchar(50) 专业 图书表:book 字段名称 数据类型 说明 stuID char(10) 学生编号,主键 stuName Varchar(10) 学生名称 major Varchar(

jQuery显示SQL存储过程自定义异常信息

学习MVC应用开发,改变了Insus.NET以前ASP.NET的开发习惯,以前开发均是服务器端,而现在使用jQuery的Ajax在实现.想到与考虑了很多问题,也遇上很多问题,一些解决了,一些还留下,望能一一把它们解决. 就如这个问题<Internal Server Error>http://www.cnblogs.com/insus/p/3418942.html 让Insus.NET印象深刻,自己解决它,花上了Insus.NET不少的时间. 今天的博文,Insus.NET就是分享一下更好的解决

sql 存储过程 循环使用

USE [clab] GO /****** Object: StoredProcedure [dbo].[sp_bd_getResultByEcd] Script Date: 08/06/2014 16:47:55 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO -- ============================================= -- Author: zhangcy -- Create date: 2