数据库

本类阅读TOP10

·SQL语句导入导出大全
·Power Designer杂记
·SQL Server日期计算
·常用的oracle函数使用说明(一)
·sqlserver2000数据库置疑的解决方法
·MS SQLServer OLEDB分布式事务无法启动的一般解决方案
·SQL to Excel 的应用
·SQL语句导入导出大全
·Error:ORA-01033:ORACLE initialization or shutdown in progress错误解决
·Oracle中password file的作用及说明

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
SQL Server 中 自定义函数 和 游标 应用的经典案例

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

    这是网友的问题,我当时立马给出了自己的解决方案,但是没有想到中间有点小问题,发现后经过自己仔细调试,完全得到正确结果后,那个网友已经结帖了。我的代码遂成为鸡肋,食之无味,弃之可惜。但是我觉得我的代码确实还是挺经典的,所以整理了一下,供各位网友欣赏。

问题:

 

假设环境如下:

    1      ID NAME      QQ     PHONE

表中数据:      1       秦云        10102800 13500000

                2       在路上      10378    13600000

                3       LEO         10000    13900000

 

    2      ID NAME  上机时间,管理员,

表中数据:     1   秦云    2004-1-1  李大伟

               2   秦云    2005-1-1  马化腾

               3    在路上  2005-1-1  马化腾

               4    秦云   2005-1-1  李大伟

               5   在路上 2005-1-1  李大伟

 

实现目的:从表1中取所有人员列表,从表2中取上机次数和管理员.

             上机人员名单    上机次数   管理员(上这几次机的每个管理员都列出来)

               秦云             3             李大伟,马化腾,李大伟

               在路上           2            马化腾,李大伟

               LEO              0      

如果不算管理员那一列的话,我是这样写的。

SELECT  1.NAME AS 姓名, COUNT(2.ID) AS 上机次数

FROM  1 LEFT OUTER JOIN

      2 ON 1.NAME = 2.NAME

GROUP BY 1.名称

 

解答:

测试用例

 

create table 1( --drop table 1

ID     int,

NAME   varchar(10),

QQ     varchar(10),

PHONE  varchar(20)

)

 

insert into 1 values(1   ,'秦云'    ,'10102800'     ,'13500000')

insert into 1 values(2   ,'在路上'  ,'10378'        ,'13600000')

insert into 1 values(3   ,'LEO'     ,'10000'        ,'13900000')

 

create table 2( --drop table 2

ID        int,

NAME    varchar(10) ,

上机时间  datetime,

管理员    varchar(10)

)

 

insert into 2  values(1,'秦云'   ,cast('2004-1-1' as datetime),'李大伟')

insert into 2  values(2,'秦云'   ,cast('2005-1-1' as datetime),'马化腾')

insert into 2  values (3,'在路上' ,cast('2005-1-1' as datetime),'马化腾')

insert into 2  values(4,'秦云'   ,cast('2005-1-1' as datetime),'李大伟')

insert into 2  values(5,'在路上' ,cast('2005-1-1' as datetime),'李大伟')

 

程序部分

 

create function GetNameStr(@name nvarchar(10))

returns nvarchar(800)

as

begin

    declare @nameStr nvarchar(800)

    declare @tempStr nvarchar(800)

    declare @flag int

    declare myCur cursor for ( select 管理员 from 2 where 2.NAME = @name )

    open myCur

    fetch next from myCur into @tempStr

    set @flag = 0

    while @@fetch_status = 0

    begin

        if @flag = 0

    begin

        set @nameStr = @tempStr

    end

    else

    begin

        set @nameStr = @nameStr + ',' + @tempStr

    end

    set @flag = @flag + 1

    fetch next from myCur into @tempStr

    end

    close myCur

    deallocate myCur

    return @nameStr

end

 

select 2.NAME as 姓名, count(ID) as 上机次数, dbo.GetNameStr(2.NAME) as 管理员

from 2

where 2.NAME in ( select 1.NAME from 1 )

group by 2.NAME

 

 

测试结果:

 

姓名    上机次数    管理员

--------------------------------------------------------------

秦云        3       李大伟,马化腾,李大伟

在路上      2       马化腾,李大伟

 




相关文章

相关软件




月光软件程序下载编程文档电脑教程网站设计网址导航网络文学游戏天地幽默笑话生活休闲写作范文安妮宝贝
电脑技术编程开发网络专区谈天说地情感世界游戏元素分类游戏热门游戏体育运动手机专区业余爱好影视沙龙
音乐天地数码广场教育园地科学大观古今纵横谈股论金人文艺术医学保健动漫图酷二手专区地方风情各行各业

月光软件站·版权所有