例外:
System.NotSupportedException: 'Zx.Data.zxEntities' 型の指定されたメソッド 'Int32 CastToInt(System.String)' は、呼び出されるインスタンスが ObjectContext ではないため、LINQ to Entities ストア式に変換できません。それが使用されているクエリが評価されます。
.edmx ファイルの宣言:
<!-- CSDL content -->
<edmx:ConceptualModels>
<Schema Namespace="zxModel" Alias="Self" xmlns:annotation="http://schemas.microsoft.com/ado/2009/02/edm/annotation" xmlns="http://schemas.microsoft.com/ado/2008/09/edm">
<!-- blah-blah-blah -->
<Function Name="CastToInt" ReturnType="Edm.Int32" >
<Parameter Name="p" Type="Edm.String" />
<DefiningExpression>
CAST (p AS Edm.Int32)
</DefiningExpression>
</Function>
</Schema>
</edmx:ConceptualModels>
.Net 関数宣言:
namespace Zx.Data
{
using System;
using System.Data.Objects;
using System.Data.Objects.DataClasses;
public partial class zxEntities
{
[EdmFunction("zxModel", "CastToInt")]
public int CastToInt(String p)
{
throw new NotSupportedException("This function is only for L2E query.");
}
}
}
関数の呼び出し:
var suppliers = entities.tblFirmPrice.Where(x => x.cat_Id == item.Cat_id)
.Join(entities.Firms, fp => fp.frm_Id, f => f.Frm_Id,
(fp, f) => new
{
fp.frm_Id,
Price = fp.fp_FirmPrice,
Discount = entities.tblFirmDiscount.Where(
x => entities.CastToInt(x.frm_id) == fp.frm_Id)
.OrderByDescending(x => x.fd_id)
.Select(x => x.fd_discount)
.FirstOrDefault(),
PriceMarkup = entities.CastToInt(
SqlFunctions.StringConvert(f.Frm_IcsAdd))
})
.Select(x => new
{
x.frm_Id,
Price = x.Price * (1 - ((((int?)x.Discount) ?? 0) / 100M)),
x.PriceMarkup
});
:-( 助言がありますか?
PS: コーディング中にhttp://msdn.microsoft.com/en-us/library/dd456857.aspx、http://msdn.microsoft.com/en-us/library/dd456857.aspxを使用