sqlserver存过,SQL SERVER存储过程

sqlserver怎么创建存储过程

1、可视化创建

专注于为中小企业提供成都网站制作、做网站服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业三江侗免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了上千家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。

a.登录SQL Server

b.打开数据库==》要创建存储过程的数据库==》可编程性==》存储过程

c.选中“存储过程”右击 ,在系出现的对话框中选择“新建存储过程”

d.在右侧出现的对话框中填写具体存储过程内容完成后执行即可

2、代码创建

a.全手写代码

一、定义变量

--简单赋值 

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 ID8 

--查询并联合两临时表 

select * from #DU_User2 where ID3 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存储过程如何建立可选参数?

SQL Server 中的存储过程(Procedure),带入参数和出参数。

存储过程(Procedure)-基本创建与操作。

--一、无参存储过程

create procedure PTitles

as

select * from titles

go

--2,执行存储过程

execute PTitles

go

--3,移除存储过程

--drop procedure PTitles

go

5.存储过程(Procedure)-带入参。

create proc P_Titles_ByType

@type char(12) --入参

as

select * from titles where type=@type

go

--,执行带参数的存储过程

--a)方式一

exec P_Titles_ByType @type='business'

go

--b)方式二

exec P_Titles_ByType 'business'

6.存储过程(Procedure)-带入参和出参。

create proc P_Titles_ByTypeAndPrice

@type char(12), --入参

@price money --入参

as  begin

select * from titles

where type=@type and price@price

end

sqlserver如何写存储过程

create proc test ------创建存储过程 test

@a int =‘’-----------创建变数 有的存储过程不需要变数,这个看个人所需要

as ---------------执行以下语句

select * from table where a=@a -------------------後面写自己需要的语句

go

--------exec test ‘1’----------执行存储过程

sqlserver存储过程怎么调试

最近在做vb项目的时候,用到了存储过程的调试,现在总结一下发现单步调试存储过程有以下2种方法:

1.这种方法自己已经做过,是可以的,如下:

a.如果目标数据库存在存储过程,右击该存储过程-修改,打开存储过程,并在需要的地方设置断点。(如果没有自定义存储过程,则需要在Sql Server 2012数据库中创建存储过程,完成后在里面设置断点);

b.另外开启一个新建查询窗口,写入调用代码:例如   exec BillManageInputProc '主单1','0111111','0111112','121','legend','2014-09-24','001','2014-09-24','1','市场部','0' ,单击 调试按钮 启动存储过程的调试;

c.单击 F 11 进行逐句调试。

2.在vs2010调试存储过程步骤如下:

首先,打开vs,点击 视图--服务器资源管理器


当前标题:sqlserver存过,SQL SERVER存储过程
转载注明:http://pcwzsj.com/article/hcdjij.html