SQLServer多表联查,多表分页查询

多表联查:

select p.*,s.sheng , i.shi
from  [dbo].[productrecordinfo]   –表名
p left join [shenginfo] s on p.shenginfo = s.shengid   –使用left join左连接 让两个表中的指定字段产生连接关系
left join [shiinfo] i on p.shiinfo = i.shiid          –使用left join左连接 让三个表中的指定字段产生连接关系

这里的 on 就类似于where,后面的条件可以自己写

运行结果如下:

 

分页sql语句:

使用row_number()函数进行编号

select * from (select row_number() over (order by id asc) as idd ,*from productrecordinfo) a where a.idd>=1 and a.idd<=3

先按id进行排序,排序完后,给每条数据进行编号。

在这个语句中row_number()函数将针对select语句返回的每一行,从1开始编号,赋予其连续的编号。在查询时应用了一个排序标准后,只有通过编号才能够保证其顺序是一致的,当使用row_number函数时,也需要专门一列用于预先排序以便于进行编号

运行结果如下:

 

 最后如果想用ado 做显示分页功能的话,就需要把多表联查跟分页结合起来,拼接语句如下:

select * from(
   select *, row_number() over(order by id asc) row from
     (select p.*,s.sheng,i.shi,a.pinpai
from  [dbo].[productrecordinfo]
p left join [shenginfo] s on p.shenginfo = s.shengid
left join [shiinfo] i on p.shiinfo = i.shiid
left join[dbo].[pinpaiinfo] a on p.pinpaiinfo=a.aid)t1)t2
where t2.row between 1 and 3

 结果如下:

 

注意事项:我们在进行数据库多表联查中必定会用到这些sql关键字,如果不弄清楚他们的区别,那就写不出来我们项目需要的查询条件。

 

(0)
上一篇 2022年3月21日
下一篇 2022年3月21日

相关推荐