`

SQL Server 存储过程示例 .

 
阅读更多
 
--有输入参数的存储过程--
create proc GetComment
(@commentid int)
as
select * from Comment where CommentID=@commentid
 
--有输入与输出参数的存储过程--
create proc GetCommentCount
@newsid int,
@count int output
as
select @count=count(*) from Comment where NewsID=@newsid
 
 
--返回单个值的函数--
create function MyFunction
(@newsid int)
returns int
as
begin
declare @count int
select @count=count(*) from Comment where NewsID=@newsid
return @count
end
 
--调用方法--
declare @count int
exec @count=MyFunction 2
print @count
 
--返回值为表的函数--
Create function GetFunctionTable
(@newsid int)
returns table
as
return
(select * from Comment where NewsID=@newsid)
 
--返回值为表的函数的调用--
select * from GetFunctionTable(2)

 

 SQLServer 存储过程中不拼接SQL字符串实现多条件查询

--以前拼接的写法
  set @sql=' select * from table where 1=1 '
  if (@addDate is not null)
   set @sql = @sql+' and addDate = '+ @addDate + ' '
  if (@name <>'' and is not null)
   set @sql = @sql+ ' and name = ' + @name + ' '
  exec(@sql)

 下面是 不采用拼接SQL字符串实现多条件查询的解决方案

  --第一种写法是 感觉代码有些冗余
  if (@addDate is not null) and (@name <> '')
   select * from table where addDate = @addDate and name = @name
  else if (@addDate is not null) and (@name ='')
   select * from table where addDate = @addDate
  else if(@addDate is null) and (@name <> '')
   select * from table where and name = @name
  else if(@addDate is null) and (@name = '')
  select * from table
  --第二种写法是
  select * from table where (addDate = @addDate or @addDate is null) and (name = @name or @name = '')
  --第三种写法是
  SELECT * FROM table where
  addDate = CASE @addDate IS NULL THEN addDate ELSE @addDate END,
  name = CASE @name WHEN '' THEN name ELSE @name END

  

SQLSERVER存储过程基本语法

一、定义变量

--简单赋值
declare  @a  int
set  @a=5
print @a
  
--使用select语句赋值
declare  @user1 nvarchar(50)
select  @user1= '张三'
print @user1
declare  @user2 nvarchar(50)
select  @user2 =  Name  from  ST_User  where  ID=1
print @user2
  
--使用update语句赋值
declare  @user3 nvarchar(50)
update  ST_User  set  @user3 =  Name  where  ID=1
print @user3
 

 

二、表、临时表、表变量

--创建临时表1
create  table  #DU_User1
(
      [ID] [ int ]   NOT  NULL ,
      [Oid] [ int ]  NOT  NULL ,
      [Login] [nvarchar](50)  NOT  NULL ,
      [Rtx] [nvarchar](4)  NOT  NULL ,
      [ Name ] [nvarchar](5)  NOT  NULL ,
      [ Password ] [nvarchar]( max )  NULL ,
      [State] [nvarchar](8)  NOT  NULL
);
--向临时表1插入一条记录
insert  into  #DU_User1 (ID,Oid,[Login],Rtx, Name ,[ Password ],State)  values  (100,2, 'LS' , '0000' , '临时' , '321' , '特殊' );
  
--从ST_User查询数据,填充至新生成的临时表
select  *  into  #DU_User2  from  ST_User  where  ID<8
  
--查询并联合两临时表
select  *  from  #DU_User2  where  ID<3  union  select  *  from  #DU_User1
  
--删除两临时表
drop  table  #DU_User1
drop  table  #DU_User2
 
--创建临时表
CREATE  TABLE  #t
(
     [ID] [ int ]  NOT  NULL ,
     [Oid] [ int ]  NOT  NULL ,
     [Login] [nvarchar](50)  NOT  NULL ,
     [Rtx] [nvarchar](4)  NOT  NULL ,
     [ Name ] [nvarchar](5)  NOT  NULL ,
     [ Password ] [nvarchar]( max )  NULL ,
     [State] [nvarchar](8)  NOT  NULL ,
)
  
--将查询结果集(多条数据)插入临时表
insert  into  #t  select  *  from  ST_User
--不能这样插入
--select * into #t from dbo.ST_User
  
--添加一列,为int型自增长子段
alter  table  #t  add  [myid]  int  NOT  NULL  IDENTITY(1,1)
--添加一列,默认填充全球唯一标识
alter  table  #t  add  [myid1] uniqueidentifier  NOT  NULL  default (newid())
  
select  *  from  #t
drop  table  #t
--给查询结果集增加自增长列
  
--无主键时:
select  IDENTITY( int ,1,1) as  ID,  Name ,[Login],[ Password ]  into  #t  from  ST_User
select  *  from  #t
  
--有主键时:
select  ( select  SUM (1)  from  ST_User  where  ID<= a.ID)  as  myID,*  from  ST_User a  order  by myID
--定义表变量
declare  @t  table
(
     id  int  not  null ,
     msg nvarchar(50)  null
)
insert  into  @t  values (1, '1' )
insert  into  @t  values (2, '2' )
select  *  from  @t

 

三、循环

--while循环计算1到100的和
declare  @a  int
declare  @ sum  int
set  @a=1
set  @ sum =0
while @a<=100
begin
     set  @ sum +=@a
     set  @a+=1
end
print @ sum

 

四、条件语句

--if,else条件分支
if(1+1=2)
begin
     print  '对'
end
else
begin
     print  '错'
end
  
--when then条件分支
declare  @today  int
declare  @week nvarchar(3)
set  @today=3
set  @week= case
     when  @today=1  then  '星期一'
     when  @today=2  then  '星期二'
     when  @today=3  then  '星期三'
     when  @today=4  then  '星期四'
     when  @today=5  then  '星期五'
     when  @today=6  then  '星期六'
     when  @today=7  then  '星期日'
     else  '值错误'
end
print @week
 

 

 五、游标 

declare  @ID  int
declare  @Oid  int
declare  @Login  varchar (50)
  
--定义一个游标
declare  user_cur  cursor  for  select  ID,Oid,[Login]  from  ST_User
--打开游标
open  user_cur
while @@fetch_status=0
begin
--读取游标
     fetch  next  from  user_cur  into  @ID,@Oid,@Login
     print @ID
     --print @Login
end
close  user_cur
--摧毁游标
deallocate  user_cur

 

 

六、触发器

  触发器中的临时表:
  Inserted
  存放进行insert和update 操作后的数据
  Deleted
  存放进行delete 和update操作前的数据

--创建触发器
Create  trigger  User_OnUpdate 
     On  ST_User 
     for  Update 
As 
     declare  @msg nvarchar(50)
     --@msg记录修改情况
     select  @msg = N '姓名从“'  + Deleted. Name  + N '”修改为“'  + Inserted. Name  +  '”'  from Inserted,Deleted
     --插入日志表
     insert  into  [LOG](MSG) values (@msg)
      
--删除触发器
drop  trigger  User_OnUpdate

 

七、存储过程

--创建带output参数的存储过程
CREATE  PROCEDURE  PR_Sum
     @a  int ,
     @b  int ,
     @ sum  int  output
AS
BEGIN
     set  @ sum =@a+@b
END
  
--创建Return返回值存储过程
CREATE  PROCEDURE  PR_Sum2
     @a  int ,
     @b  int
AS
BEGIN
     Return  @a+@b
END
      
--执行存储过程获取output型返回值
declare  @mysum  int
execute  PR_Sum 1,2,@mysum  output
print @mysum
  
--执行存储过程获取Return型返回值
declare  @mysum2  int
execute  @mysum2= PR_Sum2 1,2
print @mysum2

 

八、自定义函数
  函数的分类:
    1)标量值函数
    2)表值函数
        a:内联表值函数
        b:多语句表值函数
    3)系统函数

--新建标量值函数
create  function  FUNC_Sum1
(
     @a  int ,
     @b  int
)
returns  int
as
begin
     return  @a+@b
end
  
--新建内联表值函数
create  function  FUNC_UserTab_1
(
     @myId  int
)
returns  table
as
return  ( select  *  from  ST_User  where  ID<@myId)
  
--新建多语句表值函数
create  function  FUNC_UserTab_2
(
     @myId  int
)
returns  @t  table
(
     [ID] [ int ]  NOT  NULL ,
     [Oid] [ int ]  NOT  NULL ,
     [Login] [nvarchar](50)  NOT  NULL ,
     [Rtx] [nvarchar](4)  NOT  NULL ,
     [ Name ] [nvarchar](5)  NOT  NULL ,
     [ Password ] [nvarchar]( max )  NULL ,
     [State] [nvarchar](8)  NOT  NULL
)
as
begin
     insert  into  @t  select  *  from  ST_User  where  ID<@myId
     return
end
  
--调用表值函数
select  *  from  dbo.FUNC_UserTab_1(15)
--调用标量值函数
declare  @s  int
set  @s=dbo.FUNC_Sum1(100,50)
print @s
  
--删除标量值函数
drop  function  FUNC_Sum1

 

谈谈自定义函数与存储过程的区别:
一、自定义函数:
  1. 可以返回表变量
  2. 限制颇多,包括
    不能使用output参数;
    不能用临时表;
    函数内部的操作不能影响到外部环境;
    不能通过select返回结果集;
    不能update,delete,数据库表;
  3. 必须return 一个标量值或表变量
  自定义函数一般用在复用度高,功能简单单一,争对性强的地方。
二、存储过程
  1. 不能返回表变量
  2. 限制少,可以执行对数据库表的操作,可以返回数据集
  3. 可以return一个标量值,也可以省略return
   存储过程一般用在实现复杂的功能,数据操纵方面。

 

=========================================================================

SqlServer存储过程--实例
实例1:只返回单一记录集的存储过程。
  表银行存款表(bankMoney)的内容如下
 
Id
userID
Sex
Money
001
Zhangsan

30
002
Wangwu

50
003
Zhangsan

40
 
要求1:查询表bankMoney的内容的存储过程
create procedure sp_query_bankMoney
as
select * from bankMoney
go
exec sp_query_bankMoney
注*  在使用过程中只需要把T-Sql中的SQL语句替换为存储过程名,就可以了很方便吧!
实例2(向存储过程中传递参数):
加入一笔记录到表bankMoney,并查询此表中userID= Zhangsan的所有存款的总金额。
Create proc insert_bank @param1 char(10),@param2 varchar(20),@param3 varchar(20),@param4 int,@param5 int output
with encryption ---------加密
as
insert into bankMoney (id,userID,sex,Money)
Values(@param1,@param2,@param3, @param4)
select @param5=sum(Money) from bankMoney where userID='Zhangsan'
go
在SQL Server查询分析器中执行该存储过程的方法是:
declare @total_price int
exec insert_bank '004','Zhangsan','男',100,@total_price output
print '总余额为'+convert(varchar,@total_price)
go
在这里再啰嗦一下存储过程的3种传回值(方便正在看这个例子的朋友不用再去查看语法内容):
1.以Return传回整数
2.以output格式传回参数
3.Recordset
传回值的区别:
output和return都可在批次程式中用变量接收,而recordset则传回到执行批次的客户端中。
实例3:使用带有复杂 SELECT 语句的简单过程
  下面的存储过程从四个表的联接中返回所有作者(提供了姓名)、出版的书籍以及出版社。该存储过程不使用任何参数。
  USE pubs
IF EXISTS (SELECT name FROM sysobjects
         WHERE name = 'au_info_all' AND type = 'P')
   DROP PROCEDURE au_info_all
GO
CREATE PROCEDURE au_info_all
AS
SELECT au_lname, au_fname, title, pub_name
   FROM authors a INNER JOIN titleauthor ta
      ON a.au_id = ta.au_id INNER JOIN titles t
      ON t.title_id = ta.title_id INNER JOIN publishers p
      ON t.pub_id = p.pub_id
GO
  au_info_all 存储过程可以通过以下方法执行:
  EXECUTE au_info_all
-- Or
EXEC au_info_all
  如果该过程是批处理中的第一条语句,则可使用:
  au_info_all
实例4:使用带有参数的简单过程
  CREATE PROCEDURE au_info
   @lastname varchar(40),
   @firstname varchar(20)
AS
SELECT au_lname, au_fname, title, pub_name
   FROM authors a INNER JOIN titleauthor ta
      ON a.au_id = ta.au_id INNER JOIN titles t
      ON t.title_id = ta.title_id INNER JOIN publishers p
      ON t.pub_id = p.pub_id
   WHERE  au_fname = @firstname
      AND au_lname = @lastname
GO
  au_info 存储过程可以通过以下方法执行:
  EXECUTE au_info 'Dull', 'Ann'
-- Or
EXECUTE au_info @lastname = 'Dull', @firstname = 'Ann'
-- Or
EXECUTE au_info @firstname = 'Ann', @lastname = 'Dull'
-- Or
EXEC au_info 'Dull', 'Ann'
-- Or
EXEC au_info @lastname = 'Dull', @firstname = 'Ann'
-- Or
EXEC au_info @firstname = 'Ann', @lastname = 'Dull'
  如果该过程是批处理中的第一条语句,则可使用:
  au_info 'Dull', 'Ann'
-- Or
au_info @lastname = 'Dull', @firstname = 'Ann'
-- Or
au_info @firstname = 'Ann', @lastname = 'Dull'
 
 实例5:使用带有通配符参数的简单过程
CREATE PROCEDURE au_info2
@lastname varchar(30) = 'D%',
@firstname varchar(18) = '%'
AS
SELECT au_lname, au_fname, title, pub_name
FROM authors a INNER JOIN titleauthor ta
   ON a.au_id = ta.au_id INNER JOIN titles t
   ON t.title_id = ta.title_id INNER JOIN publishers p
   ON t.pub_id = p.pub_id
WHERE au_fname LIKE @firstname
   AND au_lname LIKE @lastname
GO
  au_info2 存储过程可以用多种组合执行。下面只列出了部分组合:
  EXECUTE au_info2
-- Or
EXECUTE au_info2 'Wh%'
-- Or
EXECUTE au_info2 @firstname = 'A%'
-- Or
EXECUTE au_info2 '[CK]ars[OE]n'
-- Or
EXECUTE au_info2 'Hunter', 'Sheryl'
-- Or
EXECUTE au_info2 'H%', 'S%'
  = 'proc2'
实例6:if...else
存储过程,其中@case作为执行update的选择依据,用if...else实现执行时根据传入的参数执行不同的修改.
--下面是if……else的存储过程:
if exists (select 1 from sysobjects where name = 'Student' and type ='u' )
drop table Student
go

if exists (select 1 from sysobjects where name = 'spUpdateStudent' and type ='p' )
drop proc spUpdateStudent
go

create table Student
(
fName nvarchar (10),
fAge
smallint ,
fDiqu varchar (50),
fTel  int
)
go

insert into Student values ('X.X.Y' , 28, 'Tesing' , 888888)
go

create proc spUpdateStudent
(
@fCase int ,
@fName nvarchar (10),
@fAge smallint ,
@fDiqu varchar (50),
@fTel  int
)
as
update Student
set fAge = @fAge, -- 传 1,2,3 都要更新 fAge 不需要用 case
fDiqu = (case when @fCase = 2 or @fCase = 3 then @fDiqu else fDiqu end ),
fTel  = (case when @fCase = 3 then @fTel else fTel end )
where fName = @fName
select * from Student
go

-- 只改 Age
exec spUpdateStudent
@fCase = 1,
@fName = N'X.X.Y' ,
@fAge = 80,
@fDiqu = N'Update' ,
@fTel  = 1010101

-- 改 Age 和 Diqu
exec spUpdateStudent
@fCase = 2,
@fName = N'X.X.Y' ,
@fAge = 80,
@fDiqu = N'Update' ,
@fTel  = 1010101

-- 全改
exec spUpdateStudent
@fCase = 3,
@fName = N'X.X.Y' ,
@fAge = 80,
@fDiqu = N'Update' ,
@fTel  = 1010101

 

 

分享到:
评论

相关推荐

    SQLServer存储过程调用WebService

    **创建存储过程示例**: ```sql CREATE PROCEDURE dbo.CallWebService @Url NVARCHAR(500), @MethodName NVARCHAR(100) AS BEGIN EXEC sp_OACreate 'WebServiceExample', @object_id OUTPUT EXEC sp_OAMethod @...

    免费的SQL Server项目和示例.pdf

    11. **SQL Server Web Tools**:基于Web的管理工具,支持账户管理、数据库和表的管理,以及查询和存储过程的创建与执行。 12. **SQL Server Community Samples**:CodePlex上的这个项目提供了大量的SQL Server示例...

    sqlserver存储过程集锦.doc

    根据给定的文件信息,以下是对SQL Server存储过程集锦中的关键知识点的详细解析: ### 1. 分页存储过程 #### 功能说明 `GetRecordSet`存储过程用于实现SQL Server中的数据分页功能。这在处理大量数据时特别有用,...

    SQL Server存储过程剖析.pdf

    综上所述,SQL Server存储过程提供了一种高效、安全和可重用的方式来封装数据库逻辑,减少前台程序的开发量,优化数据库性能,并增强了数据操作的安全性。通过学习和应用存储过程,开发者可以更有效地管理数据操作,...

    hiberate SQL Server 2000 存储过程.pdf

    标题与描述中的关键词“hibernate SQL Server 2000 存储过程”指出了本文档的主题,即在Hibernate框架下如何与SQL Server 2000的存储过程进行交互。下面将深入探讨这一主题,包括为什么在Hibernate中使用存储过程、...

    SQL Server存储过程浅析.pdf

    SQL Server存储过程是数据库编程中的一组Transact-SQL语句,它们经过编译后存储在一起,并作为单元执行。它们在服务器上创建和运行,减少了数据引擎的翻译工作,因此能提高执行效率。存储过程第一次运行可能较慢,...

    Microsoft.SQLServer.ManagedDTS.dll文件

    以下是一个简单的示例,演示如何在C#代码中使用`Microsoft.SQLServer.ManagedDTS.dll` 来执行一个已存在的SSIS包: ```csharp using System; using Microsoft.SqlServer.Dts.Runtime; namespace ...

    SQL Server 2000 Sample Databases.rar

    它们包含了创建数据库对象(如表、视图、存储过程)的SQL语句,通过运行这些脚本,用户可以在自己的SQL Server实例上重建这两个示例数据库。 5. 使用这些示例数据库,你可以学习以下知识点: - **数据库设计**:...

    Excel使用ADO调用SQL Server存储过程示例

    后期对于投票结果需要进行一些权重的计算,过程比较复杂,便想到把计算过程放在SQL Server端,使用存储过程实现。但是,在调用存储过程的过程中却遇到了问题,一直无法返回记录集。最后发现问题出现在记录集的...

    SQLServer存储过程中事务的使用方法

    本篇将详细介绍如何在SQL Server存储过程中使用事务。 首先,事务有四个基本特性,即ACID(原子性、一致性、隔离性和持久性): 1. 原子性(Atomicity):事务中的所有操作要么全部完成,要么全部不完成,不会留下...

    sqljdbc4-4.0.jar

    此外,驱动还提供了异常处理机制,如`SQLServerException`,用于捕获和处理在与SQL Server交互过程中可能出现的错误。 总的来说,"sqljdbc4-4.0.jar"是Java开发者连接和操作SQL Server数据库的重要工具,它提供了...

    SQLSERVER存储过程例子

    以下是针对"SQLSERVER存储过程例子"的详细解释。 1. **存储过程的概念**: 存储过程是一组为了完成特定功能的SQL语句,这些语句被组合在一起并保存在数据库中,用户可以通过调用存储过程的名字来执行这些语句。...

    SQL Server调用Webservice示例

    - 创建一个SQL Server存储过程,调用.NET方法。 在示例中,"SQL项目调用Webservice示例"可能包含了一个完整的.NET存储过程示例,用于演示如何构建和调用Web Service。可能的结构包括: - 存储过程源代码,展示...

    使用JSP来操作SQL SERVER中存储过程.doc

    总结来说,这个示例演示了如何在JSP中使用Java的数据库API(JDBC)调用SQL SERVER的存储过程,从而实现对数据库的增删查改操作。这种做法提高了代码的可维护性和复用性,也使得数据库操作更加高效。在实际开发中,还...

    SQL SERVER数据库开发之存储过程应用.rar

    在SQL Server数据库开发中,存储过程是至关重要的一个部分,它是一种预编译的SQL语句集合,可以被多次调用,以提高数据库操作的效率和安全性。本教程旨在深入探讨存储过程在SQL Server中的应用,帮助开发者更好地...

    SQL Server 2000 Sample Databases.zip

    SQL Server 2000 Sample Databases.zip 是一个包含SQL Server 2000的示例数据库的压缩包,主要用于帮助用户了解和学习SQL Server的功能和操作。在SQL Server环境中,示例数据库是非常宝贵的资源,因为它们提供了真实...

    Microsoft.Press.Inside.Microsoft.SQL.Server.2008.T-SQL.Programming

    它是在标准SQL基础上增加了一些特定于SQL Server的功能,如事务处理和存储过程支持等。本书深入讲解了T-SQL的基础知识及其在SQL Server 2008中的应用。 #### 三、T-SQL查询技巧 - **基本查询**:本书首先介绍了...

    【SQL Server版本】scott.rar

    标题中的"【SQL Server版本】scott.rar"表明这是一个与SQL Server相关的资源,特别是将Oracle数据库中的经典示例——Scott Schema转换为了SQL Server格式。Scott Schema是Oracle数据库学习中的一个标志性例子,通常...

    执行Sqlserver存储过程返回DataSet

    ### 执行SQL Server 存储过程并返回DataSet 在软件开发过程中,经常需要与数据库进行交互,其中一种常见的场景就是通过调用存储过程来获取数据并处理这些数据。本篇文章将详细探讨如何在C#中执行SQL Server的存储...

Global site tag (gtag.js) - Google Analytics