| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1151 人关注过本帖
标题:sql随机问题
只看楼主 加入收藏
shangxisen
Rank: 2
等 级:论坛游民
帖 子:29
专家分:46
注 册:2010-3-20
结帖率:80%
收藏
已结贴  问题点数:10 回复次数:12 
sql随机问题
我现在遇到的问题是,我要从两个不同的表中同时随机取出几条记录,然后把这些记录在放在一张表里显示,如
select top 5 * from stu1 order by newdid()     select top 5 * from stu2 order by newdid()这样写的话会出现两张表,我试过用select top 5 * from stu1 order by newid() uoion select top 5 * from stu2 order by newid()
但是提示错误,那位高手能告诉我一下,应该怎么把这两个连在一起?
搜索更多相关主题的帖子: sql 随机 
2010-07-22 17:49
cnfarer
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:179
帖 子:3330
专家分:21157
注 册:2010-1-19
收藏
得分:2 
select top 5 * into #xx from stu1 order by newid()
select top 5 * into #yy from stu2 order by newid()
select * from #xx union all select * from #yy
drop table #xx,#yy

★★★★★为人民服务★★★★★
2010-07-22 20:58
dearwolf4128
Rank: 5Rank: 5
来 自:陕西西安
等 级:职业侠客
威 望:6
帖 子:79
专家分:365
注 册:2010-7-2
收藏
得分:2 
利用union联合的表需要列的类型一致,你联合不上,估计你两个表的某个列的类型不一致,你需要使他们类型一致;另外给他们排序只能在最后一个查询表中使用,你两个都用了,也是不对的;建议你多看看书或技术手册
2010-07-23 09:08
aei135
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:12
帖 子:232
专家分:1176
注 册:2009-4-6
收藏
得分:2 
要取随机数可以先将两表连接起来再取的,当然由于排序的列不在选择列表中,所以不能直接加在第二个表的后面
select * from
(select top 5 * from stu1
union
select top 5 * from stu2) x order by newid()
2010-07-23 09:31
cnfarer
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:179
帖 子:3330
专家分:21157
注 册:2010-1-19
收藏
得分:0 
回复 4楼 aei135
这个不随机

★★★★★为人民服务★★★★★
2010-07-23 16:33
cnfarer
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:179
帖 子:3330
专家分:21157
注 册:2010-1-19
收藏
得分:0 
回复 3楼 dearwolf4128
union是不能和order by一起用的啊!

★★★★★为人民服务★★★★★
2010-07-23 16:33
dearwolf4128
Rank: 5Rank: 5
来 自:陕西西安
等 级:职业侠客
威 望:6
帖 子:79
专家分:365
注 册:2010-7-2
收藏
得分:0 
union是可以和order by一起使用的,只不过要放在最后一个表上,不能放在前面的表上,是给前面的表用了也不起作用!
2010-07-23 18:03
huxiangwenhu
Rank: 4
等 级:业余侠客
威 望:1
帖 子:191
专家分:262
注 册:2010-6-1
收藏
得分:2 
我试过了一下上面两位楼主的方法,都出现了以下错误:
服务器: 消息 205,级别 16,状态 1,行 3
包含 UNION 运算符的 SQL 语句中的所有查询都必须在目标列表中具有相同数目的表达式。
  不知道是我的表出现了问题还是怎么的。两个表为:


图片附件: 游客没有浏览图片的权限,请 登录注册

图片附件: 游客没有浏览图片的权限,请 登录注册

查询语句为:
select * from
(select top 3 * from course
union
select top 3 * from score) x order by cno

select top 3 * into #xx from score order by cno
select top 3 * into #yy from course order by cno
select * from #xx union all select * from #yy
2010-07-23 22:10
cnfarer
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:179
帖 子:3330
专家分:21157
注 册:2010-1-19
收藏
得分:0 
回复 8楼 huxiangwenhu
你的这两表字段明显是不同的,当然不能UNION了!

★★★★★为人民服务★★★★★
2010-07-24 17:21
cnfarer
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:179
帖 子:3330
专家分:21157
注 册:2010-1-19
收藏
得分:0 
回复 7楼 dearwolf4128
不起作用还叫可用?

★★★★★为人民服务★★★★★
2010-07-24 17:23
快速回复:sql随机问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.024707 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved