sql >> Database teknologi >  >> RDS >> Sqlserver

SQL Server:vælg sidste resultat fra gruppe efter

Du vil bruge vinduesfunktioner til dette i stedet for group by :

select FromUser, ToUser, Message, [Date], UserId, UserFullName, UserName, UserPhoto
from (SELECT CM.FromUser, CM.ToUser, CM.Message, CM.Date, U.UserId,
             U.UserFullName, U.UserName, U.UserPhoto,
             row_number() over (partition by CM.FromUser, CM.ToUser order by [Date] desc) as seqnum
      FROM ConversationMessages CM INNER JOIN
           Users U
           ON U.UserName = CM.FromUser
      WHERE  CM.ToUser = @user
     ) s
WHERE seqnum = 1
ORDER BY CM.Date DESC ;


  1. Hvorfor har Oracle varchar2 en obligatorisk størrelse som definitionsparameter?

  2. SQL:grupper efter fra anden tabel og inverter resultatet

  3. Hvad er den bedste måde at tømme en selvrefererende MySQL-tabel på?

  4. Sådan fungerer TIMESTAMPADD() i MariaDB