Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 7020337
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 27, 20262026-05-27T23:18:21+00:00 2026-05-27T23:18:21+00:00

In MySQL I used to be able to do something like: SELECT Something1.ID, Something2.AverageValue

  • 0

In MySQL I used to be able to do something like:

SELECT Something1.ID, Something2.AverageValue FROM
(SELECT ID, Max(Date) FROM Table GROUP BY ID) Something1
LEFT JOIN
(SELECT ID, AverageValue FROM Table) Something2
ON Something1.ID = Something2.ID

So what I am trying to do is give me the most recent averagevalue, per ID

The syntax in SQL Server appears to be different and doesn’t allow me to do the nested SELECT statements?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-27T23:18:21+00:00Added an answer on May 27, 2026 at 11:18 pm
    WITH Data AS
    (
     SELECT ROW_NUMBER() OVER (PARTITION BY ID ORDER BY Date DESC) AS Row_Number,
     ID,
     AverageValue
     FROM Table
    )
    SELECT * FROM Data WHERE Row_Number = 1
    

    This is the way you should do it in SQL Server. It makes “last/first/max/min/greatest-n-per group” easy as pie.

    PARTITION BY keyword here equals your GROUP BY statement, and the ORDER BY here would translate into the MAX aggregate function you used in MySQL

    Using this would enable you to do some fancy stuff like:

    WITH Data AS
        (
         SELECT ROW_NUMBER() OVER (PARTITION BY ID ORDER BY Date DESC) AS Row_Number,
         ID,
         AverageValue
         FROM Table
        )
    
    SELECT Newest.ID, 
    Newest.AverageValue, 
    (Newest.AverageValue - Next_Newest.AverageValue) AS AverageValue_Change,
    Newest.Date
     FROM Data Newest
    LEFT OUTER JOIN Data Next_Newest 
     ON Newest.Row_Number+1 = Next_Newest.Row_Number
    AND Newest.ID = Next_Newest.ID 
    
    WHERE Newest.Row_Number=1
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I'm moving DB from MySQL (used ODBC) to MS SQL and I want to
LIKE operator in MySql is used to find rows that contain our query text,
I used a query a few weeks ago in MySQL that described a table
I have a MYSQL table with 3 fields: CODE, DATE, COUNT. CODE is the
I used MySQL Workbench to generate a database and now I inserted it into
I've used MySQL (via PHPMyAdmin) a lot before but never really understood half of
Two libraries for Mysql. I've always used _mysql because it's simpler. Can anyone tell
I'm new to the Oracle Platform (having primarily used MySQL, with a little Postgres
Is SQL case sensitive? I've used MySQL and SQL Server which both seem to
I used to use the standard mysql_connect(), mysql_query(), etc statements for doing MySQL stuff

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.