| 网站首页 | 业界新闻 | 群组 | 交易 | 人才 | 下载频道 | 博客 | 代码贴 | 编程论坛
免费IT实战开发视频教程合集分享千里之行 始于足下
共有 540 人关注过本帖
标题:帮忙讲解一下SQL中的存储过程问题。新手。
只看楼主 加入收藏
一杯小米粥
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2018-9-8
结帖率:0
  已结贴   问题点数:10  回复次数:5   
帮忙讲解一下SQL中的存储过程问题。新手。
如果我创建一个存储过程比如
create proc A(
@one   int,
@two    varchar(200)
 )
as
begin
declar @ three int,
delcar @ four int
...
end

这个存储过程中@one,@two 和@three,@four 中的意义为什么不一样?
2018-09-08 13:07
一杯小米粥
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2018-9-8
  得分:0 
2018-09-08 14:49
mywisdom88
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:86
帖 子:2575
专家分:6316
注 册:2015-3-25
  得分:5 
create proc A(
@one   int,
 @two    varchar(200)
  )
as
 begin
 declar @ three int,
 delcar @ four int
 ...
 end
-- @one,@two 这2个变量,是存储过程的参数,是调用这个存储过程时,需要从外部传进来的
-- @three,@four 这2个变量,是存储过程内部变量,是存储过程为了完成某些任务,定义的变量,不需要外部传进来。
   
2018-09-09 23:32
wyr
Rank: 1
等 级:新手上路
帖 子:1
专家分:5
注 册:2018-9-12
  得分:5 
回复 楼主 一杯小米粥
前面两个参数@one以及@two是这个存储过程的外部参数,,,执行这个存储存储过程时需要为这两个参数赋值

而后面两个参数@three,@four是存储过程的内部参数,相当于函数中的x,y变量,当有需要时可以把结果给这个变量。
2018-09-12 11:57
mywisdom88
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:86
帖 子:2575
专家分:6316
注 册:2015-3-25
  得分:0 
其实,存储过程,还可以返回表的查询结果,如

create proc A(
@one   int,
@two   varchar(200)
   )
as
  begin
  declar @ three int,
  delcar @ four int
  select * from 你表
  end
-- 就会返回查询结果
2018-09-13 18:14







关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.035804 second(s), 8 queries.
Copyright©2004-2018, BCCN.NET, All Rights Reserved