Groups | Blog | Home
all groups > dotnet ado.net > april 2008 >

dotnet ado.net : how to extract value from LINQ query?


SftwDude
4/18/2008 5:53:02 AM
Is it possible to extract a single value from the results of a LINQ query
with out iterating over the results.

For example I have a table in SQL Server:

tblExample
Type int <--this is a key field
Descr nvarchar(5)

I would like to get the description (Descr) field something like this in C#:

string Description = from Example in db.tblExample where Example.Type = 1
select Example.Descr;

I know this query returns an IQueryable and the above query won't compile
because of type mismatch. Is there a way to get the string from the database
field using a LINQ query?

Patrice
4/18/2008 3:06:53 PM
Try :

string Description = (from Example in db.tblExample where Example.Type = 1
select Example.Descr).Single;

Single raise an exception if it does't return exactly a single record...

--
Patrice

"SftwDude" <SftwDude@nospam.nospam> a écrit dans le message de news:
C564C712-584B-4E60-A702-991DBA7CB303@microsoft.com...
[quoted text, click to view]

v-wywang@online.microsoft.com (
4/21/2008 3:52:06 AM
Thanks for Patrice's prompt reply.

Hello SftwDude

I agree with Patrice. Single () function returns only one element from
query, and throws an exception if sequence contains more than one element
or empty. Alternative way, you can use First() function to return the
first element from the query when there are more than one element in your
sequence.
For example:

string Description = (from Example in db.tblExample
where Example.Type = 1
select Example.Descr).Frist();

Hope this helps, If you have any more concern or there is anything unclear,
please feel free to let us know. We are glad to assist you.

Have a great day,
Best regards,
Wen Yuan

Microsoft Online Community Support
Delighting our customers is our #1 priority. We welcome your comments and
suggestions about how we can improve the support we provide to you. Please
feel free to let my manager know what you think of the level of service
provided. You can send feedback directly to my manager at:
msdnmg@microsoft.com.
==================================================
Get notification to my posts through email? Please refer to
http://msdn.microsoft.com/subscriptions/managednewsgroups/default.aspx#notif
ications.

Note: The MSDN Managed Newsgroup support offering is for non-urgent issues
where an initial response from the community or a Microsoft Support
Engineer within 1 business day is acceptable. Please note that each follow
up response may take approximately 2 business days as the support
professional working with you may need further investigation to reach the
most efficient resolution. The offering is not appropriate for situations
that require urgent, real-time or phone-based interactions or complex
project analysis and dump analysis issues. Issues of this nature are best
handled working with a dedicated Microsoft Support Engineer by contacting
Microsoft Customer Support Services (CSS) at
http://msdn.microsoft.com/subscriptions/support/default.aspx.
==================================================
This posting is provided "AS IS" with no warranties, and confers no rights.
AddThis Social Bookmark Button