그룹별 최대
문제:
다음에서 각 증권에 대한 최신 위치를 얻습니다. 테이블:
id | security | buy_date |
---|---|---|
26 | PCS | 2012-02-08 |
27 | PCS | 2013-01-19 |
28 | RDN | 2012-04-17 |
29 | RDN | 2012-05-19 |
30 | RDN | 2012-08-18 |
31 | RDN | 2012-09-19 |
32 | HK | 2012-09-25 |
33 | HK | 2012-11-13 |
34 | HK | 2013-01-19 |
35 | SGI | 2013-01-17 |
36 | SGI | 2013-02-16 |
KERX | 2013-02-20 | |
KERX | 0000-00-00 |
해결책:
다음 쿼리는 해당 ID와 함께 각 증권의 최대 구매 날짜를 검색합니다.
SELECT p1.id, p1.security, p1.buy_date FROM positions p1 left join positions p2 on p1.security = p2.security and p1.buy_date < p2.buy_date where p2.id is null;
이 쿼리는 Left Join을 사용하여 각 증권의 최신 위치를 효율적으로 찾습니다. 각 증권의 구매 날짜를 비교하고 이후 구매 날짜가 없는 행만 선택합니다. 이 최적화된 솔루션은 하위 쿼리 기반 접근 방식에 비해 더 빠른 실행 시간으로 정확한 결과를 보장합니다.
위 내용은 SQL을 사용하여 각 증권의 가장 최근 포지션을 찾는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!