sqlserver查询分页问题,条件比较复杂,怎样实现较好?求指点

项目有一个查询,较复杂,从多个国家到用户的查询,selecttop(10)*fromusertablewherecityidin(selectcityidformcity... 项目有一个查询,较复杂,从多个国家到用户的查询,select top(10)* from usertable where cityid in (select cityid form citytable where countryid in (select countryid from countrytable where ........)).这样一个查询,每页显示10条,现在能做出来,但每页的时间都在6s左右,好慢,能不能有别的解决办法。 展开
 我来答
百度网友02cd4ce
推荐于2016-11-01 · TA获得超过516个赞
知道小有建树答主
回答量:709
采纳率:0%
帮助的人:710万
展开全部
尽量不要使用嵌套子查询,优先使用连接子查询;
In 关键字尽量少使用,效率低,除非 in 包含的信息量非常少,并且叫固定;
如果查询条件和查询结果表无直接关联,优先根据查询条件查询出符合条件的临时结果值,然后和最终结果表关联;
除 top n 方式分页之外,使用 row_number() over 方式分页也可以;
能明确指定结果字段的,尽量不要用 * ;
不相关的字段可以省略;
如果最终结果表数据比较大,考虑分表,分区,分库;
查询结果表字段尽量不要包含大文本之类的字段;
where 条件中对于varchar 字段 的 like 查询要适度,不要用太多,会影响效率;
更多追问追答
追问
谢谢,针对我目前的这个查询,您能给个连接子查询的例子不?不用in肿么办,肿么作为查询另一个表的条件?
追答
是联接查询,打错了,你直接搜索联接查询 ,语法使用很简单,你把你的嵌套子查询替换掉就行了
例如:
select top(10) * from usertable a
inner join citytable b on a.cityid=b.cityid
inner join countrytable c on a.countryid =c.countryid

where ...
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式