sql >> Databasteknik >  >> RDS >> Sqlserver

Hur får jag aktuella uppgifter baserat på dess ikraftträdandedatum?

Jag antar att det finns andra sätt att göra detta på, men jag tror att det här fungerar:

DECLARE 
  @OrganizationID varchar(40)

SET @OrganizationID = 'SMESM1HTOVEOVE'

SELECT
  ro.ResourceID,
  ro.OrganizationID,
  max(ro.EffectiveDate)
FROM
  ResourceOrganization ro
WHERE
  ro.OrganizationID = @OrganizationID
GROUP BY
  ro.ResourceID,
  ro.OrganizationID
HAVING
  max(ro.EffectiveDate) = (
    SELECT 
      max(EffectiveDate)
    FROM 
      ResourceOrganization
    WHERE 
      ResourceID = ro.ResourceID)

Här är en SQLFiddle att leka med.

EDIT:Egentligen är det förmodligen överkomplicerat. Prova den här:

DECLARE 
  @OrganizationID varchar(40)

SET @OrganizationID = 'SMESM1HTOVEOVE'

SELECT
  ro.ResourceID,
  ro.OrganizationID,
  ro.EffectiveDate
FROM
  ResourceOrganization ro
WHERE
  ro.OrganizationID = @OrganizationID
  AND ro.EffectiveDate = (
    SELECT 
      max(EffectiveDate)
    FROM 
      ResourceOrganization
    WHERE 
      ResourceID = ro.ResourceID)


  1. ClassNotFoundException - com.microsoft.jdbc.sqlserver.SQLServerDriver

  2. Försöker skapa ett paket - fel PLS-00330

  3. GlassFish 5 och MySQL Connector

  4. Bästa sättet att INFOGA många värden i mysqli?