Solved

Concat or Union two or more entities LINQ

Posted on 2010-11-08
2
1,724 Views
Last Modified: 2012-05-10
Hello,

i am trying to do a concat or union between two or more statements, but I am getting this error

Unable to cast object of type 'System.Data.Objects.ObjectQuery`1[VB$AnonymousType_22`2[System.Int32,System.Decimal]]' to type 'System.Collections.Generic.IEnumerable`1[VB$AnonymousType_22`2[System.Int32,System.Nullable`1[System.Decimal]]]'.


In the code below you will see how I have created three seperate linq quiries that provide me with the value based on dt1 and dt2
NOTE: dt1, dt1 are strings that have date values (i.e. start date, end date )


I would like to get the (sum) of  ArAmount between all three tables in one query.


Thank you in advance
Dim qry1 = (From tr In DataContext.TransactionMain _

                              Where tr.TransactionDate >= dt1 _

                              And tr.TransactionDate <= dt2 _

                              And tr.TransactionType = Enums.TransactionType.Completed _

                              Select New With {.arAmount = tr.Amount})





Dim qry2 = (From cm In DataContext.CustomerAccountMemo _

                           Where cm.DateIssued >= dt1 _

                           And cm.DateIssued <= dt2 _

                           Select New With {.arAmount = cm.Amount})



Dim qry3 = (From pm In DataContext.Payment _

                        Where pm.CreatedOn >= dt1 _

                        And pm.CreatedOn <= dt2 _

                        Select New With {.arAmount = pm.Amount * -1})





'Now when I try to merge them as below I get an error Unable to cast object of type 'System.Data.Objects.ObjectQuery`1



Dim qry = (From tr In DataContext.TransactionMain _

                              Where tr.TransactionDate >= dt1 _

                              And tr.TransactionDate <= dt2 _

                              And tr.TransactionType = Enums.TransactionType.Completed _

                              Select New With {.id = tr.TransactionID, .arAmount = tr.Amount}) _

                          .Concat _

                          (From cm In DataContext.CustomerAccountMemo _

                           Where cm.DateIssued >= dt1 _

                           And cm.DateIssued <= dt2 _

                           Select New With {.id = cm.AccountMemoID, .arAmount = cm.Amount}) _

                       .Concat _

                       (From pm In DataContext.Payment _

                        Where pm.CreatedOn >= dt1 _

                        And pm.CreatedOn <= dt2 _

                        Select New With {.id = pm.PaymentID, .arAmount = pm.Amount * -1})





'My ultimate result is that I will have the sum of arAmount between all three tables

Open in new window

0
Comment
Question by:Teknosoft
2 Comments
 
LVL 7

Accepted Solution

by:
deadlyDev earned 250 total points
ID: 34091807
There is a mix of types in your query.

At least one of your query (I cannot be sure which without seeing your dbml) fields is a nullable decimal, and the other, or other two are plain decimals.

For whichever fields are not nullable, you should cast the return values to nullable, ie:

Select New With {.id = cm.AccountMemoID, .arAmount = CType(cm.Amount, System.Nullable(Of System.Decimal))}) _
0
 

Author Closing Comment

by:Teknosoft
ID: 34095309
You have identified and directed me to the source of the problem. One entity did have the amount as nullable=false. by just changing that I was able to use the linq query.

Thanks for your help
0

Featured Post

How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

Join & Write a Comment

Hi all, It is important and often overlooked to understand “Database properties”. Often we see questions about "log files" or "where is the database" and one of the easiest ways to get general information about your database is to use “Database p…
Occasionally there is a need to clean table columns, especially if you have inherited legacy data. There are obviously many ways to accomplish that, including elaborate UPDATE queries with anywhere from one to numerous REPLACE functions (even within…
Get a first impression of how PRTG looks and learn how it works.   This video is a short introduction to PRTG, as an initial overview or as a quick start for new PRTG users.
This demo shows you how to set up the containerized NetScaler CPX with NetScaler Management and Analytics System in a non-routable Mesos/Marathon environment for use with Micro-Services applications.

747 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

Need Help in Real-Time?

Connect with top rated Experts

11 Experts available now in Live!

Get 1:1 Help Now