第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機(jī)立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

實體框架存儲過程表值參數(shù)

實體框架存儲過程表值參數(shù)

C#
桃花長相依 2019-09-21 13:35:26
我正在嘗試調(diào)用一個接受表值參數(shù)的存儲過程。我知道Entity Framework尚不直接支持此功能,但是據(jù)我了解,您可以使用的ExecuteStoreQuery命令來實現(xiàn)ObjectContext。我有一個通用實體框架存儲庫,其中有以下ExecuteStoredProcedure方法:public IEnumerable<T> ExecuteStoredProcedure<T>(string procedureName, params object[] parameters){    StringBuilder command = new StringBuilder();    command.Append("EXEC ");    command.Append(procedureName);    command.Append(" ");    // Add a placeholder for each parameter passed in    for (int i = 0; i < parameters.Length; i++)    {        if (i > 0)            command.Append(",");        command.Append("{" + i + "}");    }    return this.context.ExecuteStoreQuery<T>(command.ToString(), parameters);}命令字符串最終如下所示:EXEC someStoredProcedureName {0},{1},{2},{3},{4},{5},{6},{7}我試圖在接受表值參數(shù)的存儲過程中運行此方法,但它會中斷。我在這里讀到,參數(shù)必須是類型SqlParameter,而表值參數(shù)需要將其SqlDbType設(shè)置為Structured。所以我這樣做了,并得到一個錯誤說明:The table type parameter p6 must have a valid type name因此,我將SqlParameter.TypeName設(shè)置為在數(shù)據(jù)庫上創(chuàng)建的用戶定義類型的名稱,然后在運行查詢時收到以下真正有用的錯誤:Incorrect syntax near '0'.如果我恢復(fù)到ADO.NET并執(zhí)行數(shù)據(jù)讀取器,則可以使查詢運行,但是我希望可以使用數(shù)據(jù)上下文使它正常工作。有沒有辦法使用傳遞表值參數(shù)ExecuteStoreQuery?另外,我實際上使用的是Entity Framework Code First,并將強制轉(zhuǎn)換DbContext為ObjectContext以獲得ExecuteStoreQuery可用的方法。這是否有必要,或者我也可以針對DbContext?
查看完整描述

3 回答

  • 3 回答
  • 0 關(guān)注
  • 523 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號