I’m developing a WCF web services and I use ADO.Net Entities to access database.
I use this method to convert some Database objects to Contract objects:
public static List<BlockContract> FormBlocks(int formId)
{
List<BlockContract> blocksList = null;
using (var vAdmEntities = new ADMDatabase.ADMEntities())
{
var blockEntities = from f in vAdmEntities.Form
where f.formId == formId
select f.Block;
if (blockEntities != null)
{
blocksList = new List<BlockContract>(blockEntities.Count());
foreach (ADMDatabase.Block b in blockEntities)
{
BlockContract blockContract = new BlockContract
{
blockId = b.blockId,
name = b.name,
orderInForm = b.orderInForm
};
blocksList.Add(blockContract);
}
}
}
return blocksList;
}
Here, foreach (ADMDatabase.Block b in blockEntities), I get an error:
Cannot convert type 'System.Data.Objects.DataClasses.EntityCollection<ADMDatabase.Block>' to 'ADMDatabase.Block'
How can I solve this error?
You need to change your loop;
you are selecting blockentities with the following;
Here if you debug blockEntities you will something like a list of lists since Form.Block is a list of block items.