首页
论坛
门户
空间
手机版
IXPUB
插件
收藏
设置
注册
登录
商店
搜索
培训
Wiki
Blog
归档
丛书
退出
ITPUB论坛
»
MS SQL Server
» xzh2000 前辈能讲讲这SQL语句(是您在一回帖中写的)的思路
‹‹ 上一主题
|
下一主题 ››
投票
交易
悬赏
活动
评价
|
打印
|
推荐
|
订阅
|
收藏
标题: xzh2000 前辈能讲讲这SQL语句(是您在一回帖中写的)的思路
ggff112
初级会员
精华贴数 0
个人空间
0
技术积分 32 (38780)
社区积分 0 (843375)
注册日期 2007-5-28
论坛徽章:0
#1
使用道具
发表于 2007-6-6 23:41
xzh2000 前辈能讲讲这SQL语句(是您在一回帖中写的)的思路
create table a_test(name varchar(20),role2 varchar(20))
insert into a_test values('李','管理員')
insert into a_test values('張','管理員')
insert into a_test values('張','一般用戶')
insert into a_test values('常','一般用戶')
select distinct name,dbo.uf_test(name) from a_test............这里的参数name是传递的什么
create function uf_test(@n varchar(30))
returns varchar(99)
as
begin
declare cur_role2 cursor local for select role2 from a_test where name =@n
declare @r varchar(30),@ret varchar(99)
open cur_role2
fetch cur_role2 into @r
while @@fetch_status = 0
begin
if @ret is null
select @ret = @r
else
select @ret = @ret + ',' +@r
fetch cur_role2 into @r....................................在循环里的fetch 是不是就相当于游标向下移一条记录,@r有什么变化,
end
close cur_role2
return @ret
end
因为刚接触游标,想问几个问题,游标cur_role2的结果集是什么样的.得到这结果集后while是如何操作的,我一直想不同的是它怎么不是把所有的role2这列的直集合在每条记录里,到底是如何结合名字判断出来那个'一般用户'应加到李而不是张'能否结合这题具体的帮我分析一下,也许吃透了这题掌握了不少的东西.最起码能明白游标的具体的操作了.
只看该作者
ggff112
初级会员
精华贴数 0
个人空间
0
技术积分 32 (38780)
社区积分 0 (843375)
注册日期 2007-5-28
论坛徽章:0
#2
使用道具
发表于 2007-6-6 23:42
补充一下,那题目是这样的:
一个SQL语句的问题:
select * from v_temp
上面的视图结果如下:
user_name role_name
-------------------------
系统管理员 管理员
feng 管理员
feng 一般用户
test 一般用户
想把结果变成这样:
user_name role_name
---------------------------
系统管理员 管理员
feng 管理员,一般用户
test 一般用户
只看该作者
棉花糖ONE
精华贴数 0
个人空间
0
技术积分 15388 (70)
社区积分 1284 (806)
注册日期 2007-2-21
论坛徽章:51
#3
使用道具
发表于 2007-6-6 23:45
楼主没必要用游标,这种方法一般都是用函数来做的,你给的那个例子写的太麻烦了
__________________
换一种思路来思考问题
qq群:47823366
只看该作者
caixia615
版主
精华贴数 2
个人空间
0
技术积分 6006 (220)
社区积分 5311 (277)
注册日期 2007-1-5
论坛徽章:10
#4
使用道具
发表于 2007-6-7 08:06
-有表t,其数据如下:
a b
1 1
1 2
1 3
2 1
2 2
3 1
--如何转换成如下结果:
a b
1 1,2,3
2 1,2
3 1
create table tb
(
a int,
b int
)
insert into tb(a,b) values(1,1)
insert into tb(a,b) values(1,2)
insert into tb(a,b) values(1,3)
insert into tb(a,b) values(2,1)
insert into tb(a,b) values(2,2)
insert into tb(a,b) values(3,1)
go
--创建一个合并的函数
create function f_hb(@a int)
returns varchar(8000)
as
begin
declare @str varchar(8000)
set @str = ''
select @str = @str + ',' + cast(b as varchar) from tb where a = @a
set @str = right(@str , len(@str) - 1)
return(@str)
End
go
--调用自定义函数得到结果:
select distinct a ,dbo.f_hb(a) as b from tb
drop table tb
--结果
a b
----------- ------
1 1,2,3
2 1,2
3 1
行列转换只需借助函数即可
__________________
如果我是你眼中的一滴泪 我会努力的流下来流到你嘴裏, 因为我真的想吻你. 如果你是我眼中的一滴泪, 那麽我会永远不会哭泣, 因为我怕失去你...
只看该作者
ggff112
初级会员
精华贴数 0
个人空间
0
技术积分 32 (38780)
社区积分 0 (843375)
注册日期 2007-5-28
论坛徽章:0
#5
使用道具
发表于 2007-6-7 10:20
很感谢楼上的兄弟朋友热情的回答,小弟在此表示感谢.
只看该作者
投票
交易
悬赏
活动
相关内容
ITPUB论坛
≡ 数据库技术 ≡
> Oracle数据库管理
> Oracle开发
> Oracle Developer Suite
> Oracle入门与认证
> Oracle专题深入讨论
> Oracle新技术/11g
> Oracle电子文档
> Oracle Application Server套件
> IBM数据库产品
> MS SQL Server
> Sybase管理与开发
> MySQL及其它开源数据库
> 内存数据库
> 数据仓库与数据挖掘
> 移动及嵌入式数据库
≡ 企业信息化 ≡
> ERP产品与实践
> CRM产品与实践
> HR产品与实践
> 物流
> 供应链
> 供应链建模与仿真
> 物流设备与系统工程
> 企业管理咨询
> 管理协同与办公自动化
> IT服务管理
> 数据中心建设
> ERP二次开发
> Oracle ERP
> EBS相关文档
> PeopleSoft与JDE
> SAP R/3
> SAP Business One开发与快速实施
> SAP财务及CRM
> SAP后勤及HR
> mySAP ERP
> 系统开发及跨应用设置
> SAP相关文档
> 国外其它ERP产品
> 国内ERP产品
≡ 开发技术 ≡
> Java入门与认证版
> Java web开发及框架技术
> Java企业开发
> ASP.NET【已迁移到微软开发技术论坛】
> .Net企业开发与应用【已迁移到微软开发技术论坛】
> WEB程序开发
> WEB 2.0技术
> 动态语言
> 移动与游戏开发
≡ 系统设计与项目管理 ≡
> 系统分析与UML
> 系统分析与UML精华区
> 项目管理
> 项目过程
> 软件测试
> 算法讨论与研究
≡ IBM软件技术园地 ≡
> IBM数据库产品
> Lotus
> Tivoli
> Websphere
> Rational
> 与SOA相关的IBM产品与技术
> IBM软件技术精英协会
> 软件技术精英活动专版
≡ 操作系统与硬件 ≡
> AIX及IBM产品【已迁移到IXPUB】
> HP-UX及HP产品【已迁移到IXPUB】
> Solaris及SUN产品【已迁移到IXPUB】
> Linux及其应用 【已迁移到IXPUB】
> 其它UNIX系统【已迁移到IXPUB】
> windows系统及微软相关产品 【已迁移到IXPUB】
> 存储设备与容灾技术 【已迁移到IXPUB】
> 服务器 【已迁移到IXPUB】
≡ 行业纵向讨论区 ≡
> IT业界评论与展望
> 政府与教育事业
> 中国政府信息主管联盟
> 电信行业
> 金融行业
> 医卫行业
> 制造行业
> 电力行业
> 信息安全与审计
≡ 会员交流 ≡
> IT职业生涯
> 招聘求职商务信息
> 体育世界
> 体育博彩专版
> 旅游,驴友
> 汽车世界
> 外语角
> 数码摄影
> 你的故事我的歌
> 音乐推荐区
> 电子图书与IT文档资料
> 软件交流
> 软件交流精华区
≡ ITPUB产品与服务 ≡
> ITPUB地面活动专版
> BLOG天地
> WIKI世界
> 授权用户区
> 站务管理
≡ 微软开发技术 ≡
> 开发工具和语言
> .NET Framework 相关
> Visual Basic/VB.net
> Visual C#
> Visual C++/vc.net
> Visual Studio
> .NET软件架构与模式
> .NET开发辅助工具及框架
> Web开发
> ASP.NET与AJAX
> Web相关技术讨论(IIS等)
> Silverlight 技术
> 微软企业级产品技术
> SQL Server
> windows server
> SharePoint
> Exchange Server
> Biztalk
> 嵌入式及移动开发
> Windows Embedded 嵌入式技术
> Windows 移动设备
> Office开发
> Microsoft office system
> Office Business Application
> 微软产品用户交流区
> .Net电子书籍&&书籍介绍
> .Net人才交流
技术积分榜
社区积分榜
徽章
电子杂志
会员
团队
统计
邮箱
游乐场
帮助
TOP
CopyRight 1999-2006 itpub.net All Right Reserved.
北京皓辰广域网络信息技术有限公司. 版权所有
E-mail:Webmaster@itpub.net
京ICP证:010037号
联系我们
法律顾问
控制面板首页
编辑个人资料
积分交易
公众用户组
好友列表
升级个人空间
基本概况
论坛排行
主题排行
发帖排行
积分排行
在线时间
管理团队
管理统计