SQL取出数据的个人小技巧

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

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值