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左右,好慢,能不能有别的解决办法。
展开
1个回答
展开全部
尽量不要使用嵌套子查询,优先使用连接子查询;
In 关键字尽量少使用,效率低,除非 in 包含的信息量非常少,并且叫固定;
如果查询条件和查询结果表无直接关联,优先根据查询条件查询出符合条件的临时结果值,然后和最终结果表关联;
除 top n 方式分页之外,使用 row_number() over 方式分页也可以;
能明确指定结果字段的,尽量不要用 * ;
不相关的字段可以省略;
如果最终结果表数据比较大,考虑分表,分区,分库;
查询结果表字段尽量不要包含大文本之类的字段;
where 条件中对于varchar 字段 的 like 查询要适度,不要用太多,会影响效率;
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 ...
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询