动网论坛,站长建站首选,国内使用量最多的论坛软件 动网论坛官方技术讨论区 站长工具 申请属于您自己的免费论坛
首页 | 新闻资讯 | 网站运营 | 网络编程 | 数据库 | 服务器 | 网页设计 | 图像媒体 | 网络应用 | 搜索优化 | 资源下载 | 动网主机 | DVBOX
    本站内  互联网 ASP论坛  ASP.Net论坛  PHP论坛
   数据库 → 阅读文章

 SQL语句和存储过程 查询语句的流程控制

作者:郁郁小蝎 来源:中国站长学院 
阅读 数 54 人次 , 2006-2-15 17:40:00 

drop table classname
declare @TeacherID int
declare @a char(50)
declare @b char(50)
declare @c char(50)
declare @d char(50)
declare @e char(50)
set @TeacherID=1

select @a=DRClass1, @b=DRClass2, @c=DRClass3, @d=DRClass4, @e=DRClass5 from Teacher Where TeacherID = @TeacherID

create table classname(classname char(50))
insert into classname (classname) values (@a)
if (@b is not null)
begin
insert into classname (classname) values (@b)

if (@c is not null)
begin
insert into classname (classname) values (@c)

if (@d is not null)
begin
insert into classname (classname) values (@d)
if (@e is not null)
begin
insert into classname (classname) values (@e)
end
end
end
end

select * from classname

以上这些SQL语句能不能转成一个存储过程?我自己试了下
ALTER PROCEDURE Pr_GetClass

@TeacherID int,
@a char(50),
@b char(50),
@c char(50),
@d char(50),
@e char(50)
as

select @a=DRClass1, @b=DRClass2, @c=DRClass3, @d=DRClass4, @e=DRClass5 from Teacher Where TeacherID = @TeacherID
DROP TABLE classname
create table classname(classname char(50))

insert into classname (classname) values (@a)
if (@b is not null)
begin
insert into classname (classname) values (@b)

if (@c is not null)
begin
insert into classname (classname) values (@c)

if (@d is not null)
begin
insert into classname (classname) values (@d)
if (@e is not null)
begin
insert into classname (classname) values (@e)
end
end
end
end

select * from classname
但是这样的话,这个存储过程就有6个变量,实际上应该只提供一个变量就可以了

主要的问题就是自己没搞清楚 @a,@b,@C,@d 等是临时变量,是放在as后面重新做一些申明的,而不是放在开头整个存储过程的变量定义。


写好的存储过程如下


create  PROCEDURE  Pr_GetClass   
@TeacherID  int
as  

Declare @a  char(50), @b  char(50), @c  char(50), @d  char(50), @e  char(50)  
select  @a=DRClass1,  @b=DRClass2,  @c=DRClass3,  @d=DRClass4,  @e=DRClass5  from  Teacher  Where  TeacherID  =  @TeacherID  
DROP  TABLE  classname  
create  table    classname(classname  char(50))  
insert  into  classname    (classname)  values  (@a)  
if  (@b  is  not  null)    
begin  
insert  into  classname    (classname)  values  (@b)  
if  (@c  is  not  null)  
   begin  
       insert  into  classname    (classname)  values  (@c)  
       if  (@d  is  not  null)    
       begin  
           insert  into  classname    (classname)  values  (@d)  
           if  (@e  is  not  null)    
           begin  
              insert  into  classname    (classname)  values  (@e)  
           end  
       end  
   end  
end   
select  *  from  classname
go



2 连表查询

我有三个表
KJ表
KJID
TeacherID
..........................................................


Teacher表

TeacherID
TeacherName
CollageID
.........................................................

Collage表

CollageID
CollageName

我想写一个SQL语句,查询所有的KJ,根据KJ的TeacherID查到TeacherName,同时根据TeacherID查到Teacher,Teacher的CollageID查到Collage,最后生成的数据集里KJ的属性里除了本身的KJName以外,还想加上TeacherName,CollageName。


语句如下

   SELECT T1.KJName, T2.TeacherName, T3.CollageName
   FROM KJ T1
   LEFT JOIN Teacher T2 ON T2.TeacherID=T1.TeacherID
   LEFT JOIN Collage T3 ON T3.CollageID=T2.CollageID


  
 本文Tags存储过程  数据库  
 收藏本文  打印本文  论坛讨论  关闭窗口
· 上一篇:SQL Server连接中三个常见的错误分析
· 下一篇:将表数据生成SQL脚本的存储过程
· SQL Server数据库技术(115)
· SQL Server数据库技术(79)
· 循序渐进学习Power Builder 6.0(10-3)
· SQL SERVER应用问题解答13例(三)
· 循序渐进学习Power Builder 6.0(12-2)


关于本站 | 联系我们 | 业务合作 | 客户案例 | 诚聘英才 | 广告合作 | 收藏本站
海口动网先锋网络科技有限公司版权所有
Copyright © 2000 - 2006 Cndw.Com
中华人民共和国电信与信息服务业务经营许可证编号 琼 ICP 020077