> 데이터 베이스 > MySQL 튜토리얼 > mysql order by操作性能问题_MySQL

mysql order by操作性能问题_MySQL

WBOY
풀어 주다: 2016-06-01 13:48:11
원래의
876명이 탐색했습니다.

bitsCN.com

在我的笔记本上,运行如下 sql代码(总共数据行约7万行,无索引)

select * from(
SELECT nodeinfo.nodeID nodeid,nodeinfo.niid niid ,nodeinfo.type type ,nodeinfo.testType testtype,sensordatapacket.storedtime storedtime,sensordatapacket.value value,
sensordatapacket.unit unit,sensordatapacket.dataType datatype,nodeconfig.nodeAddress nodename
FROM
nodeinfo
Left Join sensordatapacket ON nodeinfo.nodeID = sensordatapacket.nodeID
Left Join nodeconfig ON nodeconfig.nodeID = nodeinfo.nodeID
where  testtype='待测'  and type='土壤温度'  order by storedtime desc)  a
group by a.nodeid order by a.storedtime  desc

 

红字标注部分,使用order by storedtime desc时候 共用时9.284s

  使用order by storedtime asc时候,共用时17.04s

不使用order by操作的时候共用时2.022s。

 

目的时候对每个nodeid,检索出storedtime最近的一条数据。

若不使用order by 操作,检索出数据,storedtime时间为中间的一个某个时间。符合E.F.Codd博士在“a relation modal of data for large shared data banks”中提出的

数据库关系模型 的理论。数据库的物理存储并不一定是按照主键顺序存储,数据表中的数据本质上是在一个集合中。

bitsCN.com
관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿