VB.Net Entity Framework

Edukondalu Chellu 1 Reputation point

How to join two entities and retrieve columns from both entities as a new model list and use for each on new collection in VB.Net Entity Framework 6. any example will be helpful to learn

Microsoft Technologies based on the .NET software framework.
3,545 questions
SQL Server
SQL Server
A family of Microsoft relational database management and analysis systems for e-commerce, line-of-business, and data warehousing solutions.
13,119 questions
An object-oriented programming language developed by Microsoft that is implemented on the .NET Framework. Previously known as Visual Basic .NET.
2,637 questions
0 comments No comments
{count} votes

1 answer

Sort by: Most helpful
  1. Karen Payne MVP 35,286 Reputation points


    • This code is Entity Framework 6, database type doesn't matter so long as there is a data provider so it will work with SQL-Server, Oracle, SQLite etc.
    • All code is code first with existing database rather than using .edmx yet that should not matter.
    • In the code samples below, I only show read operations, for add/edit/remove these code samples will work with a live DbContext or detached DbContext where how you present data will dictate how to work with the projections used.

    Full source

    The following code, Customer is the main entity with contact type, contact and country.

    Imports NorthWind.Data.Contexts
    Namespace NorthWindOperations
        Public Class Operations
            Public Function CustomerJoined() As List(Of CustomerEntity)
                Using context = New NorthWindContext()
                    Return (
                            From customer In context.Customers
                            Join contactType In context.ContactTypes On customer.ContactTypeIdentifier _
                                Equals contactType.ContactTypeIdentifier
                            Join contact In context.Contacts On customer.ContactIdentifier _
                                Equals contact.ContactIdentifier
                            Join country In context.Countries On customer.CountryIdentfier _
                                Equals country.Id
                            Select New CustomerEntity With
                                    .CustomerIdentifier = customer.CustomerIdentifier,
                                    .CompanyName = customer.CompanyName,
                                    .ContactIdentifier = customer.ContactIdentifier,
                                    .FirstName = contact.FirstName,
                                    .LastName = contact.LastName,
                                    .ContactTypeIdentifier = contactType.ContactTypeIdentifier,
                                    .ContactTitle = contactType.ContactTitle,
                                    .Address = customer.Street,
                                    .City = customer.City,
                                    .PostalCode = customer.PostalCode,
                                    .CountryIdentifier = customer.CountryIdentfier,
                                    .CountyName = country.CountryName}
                End Using
            End Function
        End Class
    End Namespace

    Class for above return type

    Note for each table I include the primary key so if needed updates can be done to the database tables.

    Namespace NorthWindOperations
        Public Class CustomerEntity
            Public Property CustomerIdentifier As Integer
            Public Property CompanyName As String
            Public Property ContactTitle As String
            Public Property ContactIdentifier As Integer?
            Public Property ContactTypeIdentifier As Integer
            Public Property FirstName As String
            Public Property LastName As String
            Public Property PostalCode As String
            Public Property CountryIdentifier As Integer?
            Public Property CountyName As String
            Public Property Address As String
            Public Property City As String
            Public Overrides Function ToString() As String
                Return $"{CustomerIdentifier} {CompanyName}"
            End Function
        End Class
    End NameSpace

    Off topic

    If Entity Framework Core was being used see the following GitHub repository.

    0 comments No comments