1

例外:

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.aspxhttp://msdn.microsoft.com/en-us/library/dd456857.aspxを使用

4

1 に答える 1

0

Convert.ToInt32 メソッドを使用してみましたか?

Discount = entities.tblFirmDiscount.Where(
              x => Convert.ToInt32(x.frm_id) == fp.frm_Id)
于 2012-12-27T23:43:38.637 に答える