SolvedPrivate

Help writing a C# function which returns the ID of the last record in a table

Posted on 2014-04-19
14
72 Views
1 Endorsement
Last Modified: 2016-02-16
I need help writing a C# Function using LINQ that will return me the ID of the last record from a table named Books in an SQL Server Database named MyLibrary.
I have named DbContext in my application MyLibraryDbContext.

I am using Entity Framework 6 (LINQ to Entities). The data is already in my application and can be retrieved using MyLibraryDbContext.

The function I need will look like something as below:

public int GetIdOfLastRecord()
{
MyLibraryDbContext context = new MyLibraryDbContext();

int ID;

// Code here

return ID;
}

Thank you for your help.
1
Comment
Question by:FaheemAhmadGul
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 6
  • 6
  • 2
14 Comments
 
LVL 44

Expert Comment

by:AndyAinscow
ID: 40010121
http://www.experts-exchange.com/Programming/Languages/C_Sharp/Q_28415797.html

ps.  That is your previous question.

edit, appended:
Exactly what do you mean by last?  Is the table sorted in the way you require?
0
 
LVL 1

Author Comment

by:FaheemAhmadGul
ID: 40010172
Thank you for your comment.
I think this question is slightly different from my previous question. In my previous question, I wanted my Function to take a string parameter, then check if a record exists in the Books table that matches the string passed to it and return the ID of the record if it exists.
In my current question, I just want the ID of the last record from this table named Books. This new function does not take any parameters and just returns the ID of the last record whatever it is.
0
 
LVL 44

Expert Comment

by:AndyAinscow
ID: 40010173
I appreciate there is a difference.

Exactly what do you mean by last?  Is the table sorted in the way you require?
0
NFR key for Veeam Backup for Microsoft Office 365

Veeam is happy to provide a free NFR license (for 1 year, up to 10 users). This license allows for the non‑production use of Veeam Backup for Microsoft Office 365 in your home lab without any feature limitations.

 
LVL 1

Author Comment

by:FaheemAhmadGul
ID: 40010181
By last record I mean the most recently added record, that is the record with the highest ID. So if the table has just three records, the record with the ID =3 will be the last record. If you consider the table data shown in my previous question with a similar theme, the last record will be the record that has BookTitle Emma. I am supposing the data in the table is sorted based on ID field (record with ID = 1 being considered the first record).
0
 
LVL 44

Expert Comment

by:AndyAinscow
ID: 40010188
Something like this:
var CustID= BooksDBContext.Customers
                       .Where(p => p.max(ID))
                       .ID;
0
 
LVL 1

Author Comment

by:FaheemAhmadGul
ID: 40010194
I do not get any option like max after typing
   .Where(p => p.
0
 
LVL 44

Expert Comment

by:AndyAinscow
ID: 40010291
Does this work
var CustID= BooksDBContext.Customers.ID.Max();
0
 
LVL 1

Author Comment

by:FaheemAhmadGul
ID: 40010330
This does not work either.
0
 
LVL 1

Author Comment

by:FaheemAhmadGul
ID: 40010332
I did not think it would be such a difficult task. I am increasing the points to 200 now.
0
 
LVL 44

Expert Comment

by:AndyAinscow
ID: 40010359
I'm not having a good day, sorry.

Please try this - I was thinking too much in SQL in my first code.  (The following or similar will work when using a collection in C#, not to certain about LINQ to ENTITY though).

var CustID= BooksDBContext.Customers
                       .Where(p => p.ID.Max())
                       .ID;

If it doesn't work do you mean it doesn't compile or runs with an error or runs but not returns what you expect



ps.  I've done a google search and the following might be useful:
http://stackoverflow.com/questions/3299545/linq-to-entities-easy-to-find-max-value-in-sql-but-difficult-in-linq
0
 
LVL 63

Accepted Solution

by:
Fernando Soto earned 200 total points
ID: 40010639
Hi FaheemAhmadGul;

You can place the following code snippet in to the function and it should return the value you are looking for.

MyLibraryDbContext context = new MyLibraryDbContext();

var maxID = (from b in context.Books
             orderby b.ID descending
             select b.ID).FirstOrDefault( );

Open in new window

0
 
LVL 1

Author Closing Comment

by:FaheemAhmadGul
ID: 40010679
This has worked perfectly. Thank you. I am very grateful. Regards, Faheem
0
 
LVL 63

Expert Comment

by:Fernando Soto
ID: 40010711
Not a problem Faheem, glad I was able to help.
0
 
LVL 44

Expert Comment

by:AndyAinscow
ID: 40011106
Just don't forget the sorting may be very time consuming - it depends on how many records you are working with.
0

Featured Post

What Is Blockchain Technology?

Blockchain is a technology that underpins the success of Bitcoin and other digital currencies, but it has uses far beyond finance. Learn how blockchain works and why it is proving disruptive to other areas of IT.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Why is this different from all of the other step by step guides?  Because I make a living as a DBA and not as a writer and I lived through this experience. Defining the name: When I talk to people they say different names on this subject stuff l…
What if you have to shut down the entire Citrix infrastructure for hardware maintenance, software upgrades or "the unknown"? I developed this plan for "the unknown" and hope that it helps you as well. This article explains how to properly shut down …
Viewers will learn how the fundamental information of how to create a table.
Viewers will learn how to use the SELECT statement in SQL to return specific rows and columns, with various degrees of sorting and limits in place.

635 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question