免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2391 | 回复: 9
打印 上一主题 下一主题

求教,SQL写法 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-06-23 21:41 |只看该作者 |倒序浏览
表  t1
NO.         name       sex
001          王         男
002          李         男



表   t2
NO.          爱好
001          打球
001          游泳
001          电脑
002          爬山


要输出的结果是
NO         name          sex              爱好
001        王           男          打球,游泳,电脑(这里中间不加","也可以)
002        李           男          爬山

不知道这该怎么写,请教各位了。。。

论坛徽章:
71
15-16赛季CBA联赛之同曦
日期:2018-08-23 15:41:42辰龙
日期:2014-08-15 09:07:43狮子座
日期:2014-06-03 13:55:33亥猪
日期:2014-06-02 11:17:08巨蟹座
日期:2014-05-06 10:02:03午马
日期:2014-05-04 08:18:27亥猪
日期:2014-04-29 11:11:32技术图书徽章
日期:2014-04-24 15:51:26技术图书徽章
日期:2014-04-17 11:01:53辰龙
日期:2014-04-15 12:45:46亥猪
日期:2014-04-11 09:06:23射手座
日期:2014-04-01 15:28:10
2 [报告]
发表于 2008-06-23 23:06 |只看该作者

  1. CREATE FUNCTION JoinSTR
  2. (
  3. @no INT
  4. )
  5. RETURNS VARCHAR(1000)
  6. AS
  7. BEGIN
  8.     DECLARE @s VARCHAR(1000)
  9.     SELECT @s=ISNULL(@s+',','') + 爱好 FROM t2 WHERE no = @no
  10.     RETURN @s
  11. END
  12. GO
  13. SELECT DISTINCT t1.no,t1.name,t1.sex,dbo.JoinSTR(t2.no) 爱好 FROM t1,t2 where t1.no=t2.no
  14. drop function joinstr
  15. GO
复制代码

[ 本帖最后由 zhaopingzi 于 2008-6-24 00:32 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2008-06-24 09:49 |只看该作者
写一个聚合函数, 可参考

http://blog.chinaunix.net/u/7667/showart_165144.html

论坛徽章:
1
丑牛
日期:2014-08-07 17:07:05
4 [报告]
发表于 2008-06-24 13:52 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
5 [报告]
发表于 2008-06-24 21:19 |只看该作者
是10.0g   现在还有一个问题就是要把数据导出到文件里。。。难道得加个临时表吗?

论坛徽章:
1
丑牛
日期:2014-08-07 17:07:05
6 [报告]
发表于 2008-06-25 11:08 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
7 [报告]
发表于 2008-06-26 08:28 |只看该作者
写函数来实现不错

论坛徽章:
0
8 [报告]
发表于 2008-06-26 11:05 |只看该作者
楼主呢,出来说说现在问题解决了吗?

我看2楼的函数好像不能执行;6楼写的可能在10g上能够执行,但直接存为txt格式很不方便看吧?

论坛徽章:
0
9 [报告]
发表于 2008-06-26 13:26 |只看该作者
原帖由 ILoveMK 于 2008-6-25 11:08 发表
spool 'C:\result.txt'
select t1.no,t1.name,t1.sex,t3.爱好
from t1,(select no,wmsys.wm_concat(爱好) 爱好 from t2 group by no) t3
where t1.no=t3.no;
spool off

标红的是系统视图吗?没见过~

论坛徽章:
0
10 [报告]
发表于 2008-06-26 20:35 |只看该作者
哈哈。。。。二楼的方法我不太会用。。。我也不知道能用不。。。

六楼的方法不错。可以用。谢谢了。。。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP