我做一个石油报价系统,要求数据要能以后统计的 但是随着数据量越来越大 读取的时候重复数据太多 本人对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来取出相应的名称 这就完成了数据还不重复