SqlSever N层表数据查询效率

在做数据查询时INNER JOIN 可以说是最熟悉的一个关键字之一了。例如通常查询一个客户的订单详细信息时可能会有这样的Sql:

 Select * From Orders A
   
Inner Join CustomerOrders B On B.Order_Id = A.Order_Id
   
Inner Join Customers C On C.Customer_Id = B.Customer_Id
   
Where C.Customer_Name = ‘Jack’

这样的查询对数据库来说是非常快的,因此也习惯了这样用,用几个表Join几个表。但是随着Join的表越多查询的性能会急剧下降。为了提高查询这种深层次对象的效率,采用了一种折中的办法就是将相邻两个表作join将主键插入一个表变量,然后作为下一个表查询的条件,上面的Sql就会变成:
 

Declare @customer_temp Table(Customer_Id int);
 
Insert Into @customer_temp
  
Select Customer_Id 
 
From Customers
 
Where Customer_Name = ‘Jack’
 
 
Declare @cutomerorders_temp Table ( Customer_Id int,Order_Id int);
 
Insert Into @cutomerorders_temp
 
Select Customer_Id,Order_id 
 
From CustomerOrders A
 
Inner Join @customer_temp B On B.Customer_Id = A.Customer_Id
 
 
Select * From Orders A
  
Inner Join @cutomerorders_temp B On B.Order_Id = A.Order_Id 


 
 这样做的好处在于表的层次非常深,根据一个顶层对象查询一个底层表时效率会比直接join高上很多。Join 表的次数如果达9层时查询几乎是非常困难的,如果用这种方式表的嵌套可以在20级左右效率还是可以承受,但是像那种层次100多级就够呛了(不知道那位仁兄做过这样的研究,现在为这个问题头疼)。当然如果需要同时返回多个表中的列这种方式就不行了,例如:

Select A.OrderNo,C.Customer_Name From Orders A
  
Inner Join CustomerOrders B On B.Order_Id = A.Order_Id
  
Inner Join Customers C On C.Customer_Id = B.Customer_Id
  
Where C.Customer_Name = ‘Jack’

 

PS:可能解决这种问题的方式很多,自己也在不断的尝试新的办法。借此抛砖引玉,看各位看官能否有更好的意见和建议。


 

 

posted on 2007-11-02 11:08  Kain  阅读(2132)  评论(7编辑  收藏  举报

导航