SQL Server 中 自定义函数 和 游标 应用的经典案例
来源:互联网 发布:ubuntu系统语言灰色 编辑:程序博客网 时间:2024/05/17 21:38
这是网友的问题,我当时立马给出了自己的解决方案,但是没有想到中间有点小问题,发现后经过自己仔细调试,完全得到正确结果后,那个网友已经结帖了。我的代码遂成为鸡肋,食之无味,弃之可惜。但是我觉得我的代码确实还是挺经典的,所以整理了一下,供各位网友欣赏。
问题:
假设环境如下:
表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 马化腾,李大伟
- SQL Server 中 自定义函数 和 游标 应用的经典案例
- SQL Server 中 自定义函数 和 游标 应用的经典案例
- SQL Server 中 自定义函数 和 游标 应用的经典案例
- SQL Server 中 自定义函数 和 游标 应用的经典案例
- SQL Server中自定义函数和游标应用的经典案例
- 中自定义函数和游标应用的经典案例
- SQL Server中随机函数的应用
- sql server中自定义函数
- SQL Server中动态游标的定义
- 【Vegas原创】SQL Server游标的经典使用
- 【Vegas原创】SQL Server游标的经典使用
- SQL Server游标应用实例
- SQL SERVER中如何在函数中模拟游标
- SQL Server中游标加锁技术应用:获取唯一编号
- SQL Server 2005 自定义聚合函数应用
- SQL SERVER中SQL中游标嵌套循环的示例
- sql server 函数,存储过程,游标以及while和if语句的嵌套使用
- SQL SERVER用户自定义函数的创建和使用
- ISAPI_Rewrite Lite
- 支持断点续传的多文件上传开发控件
- 我做好辞职的准备了吗?
- 从面试题目开始(5)
- 渡河问题
- SQL Server 中 自定义函数 和 游标 应用的经典案例
- C++ STL简介
- 三十分钟掌握STL
- flash白板功能
- 我写的MMORPG服务器端的设计
- 存储过程实现数据导入导出(SQL Server)
- 一个将阿拉伯数字转换成中文大写的好算法(C#)
- 註冊表讀寫公共函數
- PPC扑克牌游戏开发实录 第一篇 之 全屏