求sql多表嵌套查询

我有两张表:song_info和singer_info两张表依靠singer_id连接。我想从第9行开始往下查8行:selecttop17so.song_name,si.... 我有两张表 :song_info 和singer_info 两张表依靠singer_id连接。我想从第9行开始往下查8行:
select top 17 so.song_name ,si.singer_name
from song_info as so ,singer_info as si
where so.singer_id = si.singer_id
AND so.song_name ,si.singer_name NOT IN
(SELECT TOP 8 song_name FROM song_info)
求高手指点;
展开
 我来答
手机用户61226
2012-07-25
知道答主
回答量:17
采纳率:0%
帮助的人:10.3万
展开全部
要用连表查询
SELECT * FROM song_info so LEFT JOIN singer_info si ON so.singer_id = si.singer_id;
你要其他字段的化就把 * 改成你要的字段;
更多追问追答
追问
第一遍查询前8条记录查出来了 第二遍从第9条开始到第16条就查不出来了
追答
哦,不好意思啊,前面没看见你是sql server 数据库
select top 8 * from(select top 17 * FROM song_info so LEFT JOIN singer_info si ON so.singer_id = si.singer_id order by so.singer_id)s order by s.singer_id

sql server 不是很熟悉,你试一下,
我的思路的用联合查询查出前17条然后倒叙排列,再查出前8条倒叙排列,就是你要的结果了
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
flower_wzm
2012-07-25 · TA获得超过921个赞
知道小有建树答主
回答量:636
采纳率:0%
帮助的人:288万
展开全部
什么数据库啊,不同数据库写法不同啊
更多追问追答
追问
sql server 数据库
追答
select top 8 * from song_info s,singer_info where (id>select max(so.singer_id) from (select top 9 so.singer_id from song_info so,singer_info si where so.singer_id = si.singer_id order by so.singer_id))order by s.singer_id ;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式