SQL取出数据的个人小技巧

来源:互联网 发布:内网远程桌面软件 编辑:程序博客网 时间:2024/05/14 06:01

我做一个石油报价系统,要求数据要能以后统计的  但是随着数据量越来越大 读取的时候重复数据太多 本人对SQL太菜 所以苦思冥想 终于把所需要的数据取出来了...

有两个表 一个是石油的名称表 ,另外一个是报价表

读取报价的时候不能把重复读取出数据只能每一种读取最近的记录,由于我是每次更新都相应插入一条数据 所以有一定的特殊性,因为相同的名称的最大ID就是最近插入的 下面是语句

 

use shiyou
select petroleum_name.*,ww.price,ww.datetime
from
petroleum_name
inner join
(select * from price where id in (select max(id)as ma from price group by p_id))as ww
 on
 petroleum_name.id=ww.p_id
order by
datetime desc


 

select max(id)as ma from price group by p_id

这一句是取出每种产品报价最大ID  

(select * from price where id in (select max(id)as ma from price group by p_id))as ww 

这句是利用刚才取出的ID取出相应的条目

取出需要的数据了 但是p_id是对于的petroleum_name表中的id  还没有取出名称 在使用 inner join来取出相应的名称 这就完成了数据还不重复

 

原创粉丝点击