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关键字,如果不弄清楚他们的区别,那就写不出来我们项目需要的查询条件。
上一篇: 容易被误读的iostat
下一篇: 性能调优5:执行计划