1

わかりました、ここで少し困惑しました。これ以上頭を悩ませる代わりに、ここにいるすべての明るい人々にこれを放り投げようと思いました.

私は、WinApp ソリューションに Entity Framework と c# を使用しています。問題の核心は、私のシステムでは問題なく動作するのに、デプロイ後に失敗することです。展開したアプリを開発システムにインストールしても失敗します。それは少し気がかりです。

問題の核心と大胆に。ユーザーが検索を実行し、クエリを作成し、ExecuteStoreQuery 呼び出しを介して SQL をタップし、SearchResult オブジェクトの汎用リストを返します。

呼び出し:

retVal = ctx.ExecuteStoreQuery<SearchResults>(sql).ToList();

代替呼び出しでも同じエラーが生成されます。

ObjectQuery<DbDataRecord> c = ctx.CreateQuery<DbDataRecord>(sql);

エラー:

************** Exception Text **************
System.Reflection.ReflectionTypeLoadException: Unable to load one or more of the requested types. Retrieve the LoaderExceptions property for more information.
   at System.Reflection.RuntimeModule.GetTypes(RuntimeModule module)
   at System.Reflection.RuntimeModule.GetTypes()
   at System.Reflection.Assembly.GetTypes()
   at System.Data.Metadata.Edm.ObjectItemConventionAssemblyLoader.LoadTypesFromAssembly()
   at System.Data.Metadata.Edm.ObjectItemAssemblyLoader.Load()
   at System.Data.Metadata.Edm.AssemblyCache.LoadAssembly(Assembly assembly, Boolean loadReferencedAssemblies, ObjectItemLoadingSessionData loadingData)
   at System.Data.Metadata.Edm.AssemblyCache.LoadAssembly(Assembly assembly, Boolean loadReferencedAssemblies, ObjectItemLoadingSessionData loadingData)
   at System.Data.Metadata.Edm.AssemblyCache.LoadAssembly(Assembly assembly, Boolean loadReferencedAssemblies, ObjectItemLoadingSessionData loadingData)
   at System.Data.Metadata.Edm.AssemblyCache.LoadAssembly(Assembly assembly, Boolean loadReferencedAssemblies, ObjectItemLoadingSessionData loadingData)
   at System.Data.Metadata.Edm.AssemblyCache.LoadAssembly(Assembly assembly, Boolean loadReferencedAssemblies, KnownAssembliesSet knownAssemblies, EdmItemCollection edmItemCollection, Action`1 logLoadMessage, Object& loaderCookie, Dictionary`2& typesInLoading, List`1& errors)
   at System.Data.Metadata.Edm.ObjectItemCollection.LoadAssemblyFromCache(ObjectItemCollection objectItemCollection, Assembly assembly, Boolean loadReferencedAssemblies, EdmItemCollection edmItemCollection, Action`1 logLoadMessage)
   at System.Data.Metadata.Edm.MetadataWorkspace.ImplicitLoadAssemblyForType(Type type, Assembly callingAssembly)
   at System.Data.Objects.ObjectContext.ExecuteStoreQueryInternal[TElement](String commandText, String entitySetName, MergeOption mergeOption, Object[] parameters)
   at AMMCred.Data.Search.GetSearchResults(SearchTerms terms)
   at AMMCred.frmMain.openProviderInfoToolStripMenuItem_Click(Object sender, EventArgs e)
   at System.Windows.Forms.ToolStripItem.RaiseEvent(Object key, EventArgs e)
   at System.Windows.Forms.ToolStripMenuItem.OnClick(EventArgs e)
   at System.Windows.Forms.ToolStripItem.HandleClick(EventArgs e)
   at System.Windows.Forms.ToolStripItem.HandleMouseUp(MouseEventArgs e)
   at System.Windows.Forms.ToolStripItem.FireEventInteractive(EventArgs e, ToolStripItemEventType met)
   at System.Windows.Forms.ToolStripItem.FireEvent(EventArgs e, ToolStripItemEventType met)
   at System.Windows.Forms.ToolStrip.OnMouseUp(MouseEventArgs mea)
   at System.Windows.Forms.ToolStripDropDown.OnMouseUp(MouseEventArgs mea)
   at System.Windows.Forms.Control.WmMouseUp(Message& m, MouseButtons button, Int32 clicks)
   at System.Windows.Forms.Control.WndProc(Message& m)
   at System.Windows.Forms.ScrollableControl.WndProc(Message& m)
   at System.Windows.Forms.ToolStrip.WndProc(Message& m)
   at System.Windows.Forms.ToolStripDropDown.WndProc(Message& m)
   at System.Windows.Forms.Control.ControlNativeWindow.OnMessage(Message& m)
   at System.Windows.Forms.Control.ControlNativeWindow.WndProc(Message& m)
   at System.Windows.Forms.NativeWindow.Callback(IntPtr hWnd, Int32 msg, IntPtr wparam, IntPtr lparam)

SearchResults は次のようなカスタム オブジェクトです。

public class SearchResults : IEquatable<SearchResults>
{
    private Guid id = Guid.Empty;
    public Guid PROV_MPI_NO
    {
        get { return id; }
        set { id = value; }
    }
    private string iPA = "";
    public string IPA
    {
        get { return iPA; }
        set { iPA = value; }
    }
    private string firstName = "";
    public string FirstName
    {
        get { return firstName; }
        set { firstName = value; }
    }
    private string middleName = "";
    public string MI
    {
        get { return middleName; }
        set { middleName = value; }
    }
    private string lastName = "";
    public string LastName
    {
        get { return lastName; }
        set { lastName = value; }
    }
    private string license = "";
    public string License
    {
        get { return license; }
        set { license = value; }
    }
    private string provId = "";
    public string ProvId
    {
        get { return provId; }
        set { provId = value; }
    }
    /// <summary>
    /// Used to help identify duplicates in a collection
    /// </summary>
    /// <param name="other"></param>
    /// <returns></returns>
    public bool Equals(SearchResults other)
    {
        return (this.PROV_MPI_NO == other.PROV_MPI_NO && this.License == other.License);
    }
}

最後に、検索結果を取得するために使用される SQL の選択部分を次に示します。

SELECT a.PROV_MPI_NO, b.COMPANY_ID AS IPA, a.FIRSTNAME,a.MI,a.LASTNAME, b.PROVID, c.LICENSE

SQLの結果をカスタムオブジェクトにバインドしているため、問題はEntity Framework内から発生しているようです。問題が発生した場合に備えて、カスタム オブジェクト フィールド名が SQL フィールドと同じであることを確認しましたが、そうではないようでした。

私が出発する時が近づいています。私は週末中ずっと考えているので、時々チェックして、誰かが持っているかもしれない質問に答えるでしょう.

私が言ったように、私は現時点で完全に困惑しており、誰かの洞察に感謝します.

前もって感謝します!

ウェイン

2011 年 11 月 14 日更新---------- Assembly Binding Log Viewer ツールを実行したところ、次の結果が得られました。Microsoft.Practices.Unity が読み込まれていないようです。つまり、私は一度もこれらの Practices アセンブリをアプリケーションで参照したことはありませんが、System.Data.Entity は参照しているようです。それはリードです...この新しい開発に関する情報は非常に高く評価されています.

*** Assembly Binder Log Entry  (11/14/2011 @ 3:10:52 PM) ***

The operation failed.
Bind result: hr = 0x80070002. The system cannot find the file specified.

Assembly manager loaded from:  C:\Windows\Microsoft.NET\Framework\v4.0.30319\clr.dll
Running under executable  C:\Users\***me***\AppData\Local\Apps\2.0\1ND1AZ7G.HEJ\CWDQKK8A.LVO\ammc..tion_0000000000000000_0002.0000_456d6de62e1c40e4\AMMCred2.exe
--- A detailed error log follows. 

=== Pre-bind state information ===
LOG: User = ***me***
LOG: DisplayName = Microsoft.Practices.Unity, Version=1.2.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35
 (Fully-specified)
LOG: Appbase = file:///C:/Users/***me***/AppData/Local/Apps/2.0/1ND1AZ7G.HEJ/CWDQKK8A.LVO/ammc..tion_0000000000000000_0002.0000_456d6de62e1c40e4/
LOG: Initial PrivatePath = NULL
LOG: Dynamic Base = NULL
LOG: Cache Base = NULL
LOG: AppName = AMMCred2.exe
Calling assembly : Microsoft.Practices.EnterpriseLibrary.Common, Version=4.1.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35.
===
LOG: This bind starts in default load context.
LOG: Using application configuration file: C:\Users\***me***\AppData\Local\Apps\2.0\1ND1AZ7G.HEJ\CWDQKK8A.LVO\ammc..tion_0000000000000000_0002.0000_456d6de62e1c40e4\AMMCred2.exe.config
LOG: Using host configuration file: 
LOG: Using machine configuration file from C:\Windows\Microsoft.NET\Framework\v4.0.30319\config\machine.config.
LOG: Post-policy reference: Microsoft.Practices.Unity, Version=1.2.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35
LOG: GAC Lookup was unsuccessful.
LOG: Attempting download of new URL file:///C:/Users/***me***/AppData/Local/Apps/2.0/1ND1AZ7G.HEJ/CWDQKK8A.LVO/ammc..tion_0000000000000000_0002.0000_456d6de62e1c40e4/Microsoft.Practices.Unity.DLL.
LOG: Attempting download of new URL file:///C:/Users/***me***/AppData/Local/Apps/2.0/1ND1AZ7G.HEJ/CWDQKK8A.LVO/ammc..tion_0000000000000000_0002.0000_456d6de62e1c40e4/Microsoft.Practices.Unity/Microsoft.Practices.Unity.DLL.
LOG: Attempting download of new URL file:///C:/Users/***me***/AppData/Local/Apps/2.0/1ND1AZ7G.HEJ/CWDQKK8A.LVO/ammc..tion_0000000000000000_0002.0000_456d6de62e1c40e4/Microsoft.Practices.Unity.EXE.
LOG: Attempting download of new URL file:///C:/Users/***me***/AppData/Local/Apps/2.0/1ND1AZ7G.HEJ/CWDQKK8A.LVO/ammc..tion_0000000000000000_0002.0000_456d6de62e1c40e4/Microsoft.Practices.Unity/Microsoft.Practices.Unity.EXE.
LOG: All probing URLs attempted and failed.
4

2 に答える 2

1

エラーはロード例外です。

これは開発では機能しますが、展開されたプログラムでは機能しないため、おそらく dll が含まれていないことが原因です。

VS プロジェクトに移動し、参照を展開して各 dll のプロパティを確認し、展開されていない dll に対して local = true がコピーされていることを確認します。

于 2011-11-13T20:35:47.790 に答える
0

バインド結果に基づいて、アプリケーションで Microsoft.Practices.Unity.DLL をデプロイしていないようです。そして、これは Microsoft.Practices.EnterpriseLibrary.Common から参照されているように見えます。そのため、直接参照していません。

Enterprise Library のさまざまな依存関係について説明している MSDN の記事を次に示します。

アップデート

ildasm.exe (C:\Program Files (x86)\Microsoft SDKs\Windows\v7.0A\Bin) を使用して System.Data.Entity の直接的な依存関係を確認したところ、エンタープライズ ライブラリを参照していません。一般に、システム DLL とオプションの製品 DLL の間に依存関係が作成されないため (これだけの理由で)、それがあったとしたら非常に驚きました。

これを含む可能性のある他の DLL/参照を取り込みますか? 不明な場合は、ildasm.exe を使用して DLL に移動し、そのマニフェストを開くことができます。少し読みにくいですが、次のような参考文献を探しています。

module extern 'System.Data.dll, System.Data, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089'

.assembly extern System.Data
于 2011-11-15T00:02:28.750 に答える