簡體   English   中英

如何在微風 js 中捕獲 sql 異常

[英]how to catch sql exception in breeze js

我的 HotTowel 模板有問題。 如何在微風 js 中捕獲 sql 重復唯一鍵值異常並顯示?

我的 controller:

[BreezeController]
    [System.Web.Http.Authorize]
    public partial class DataServiceController : ApiController
    {
        [System.Web.Http.HttpPost]
        public SaveResult SaveChanges(JObject saveBundle)
        {
            SaveResult result;
            try
            {
                result = this._contextProvider.SaveChanges(saveBundle, null);
            }
            catch (Exception ex)
            {
                throw ex;
            }
            return result;
        }
    }

當數據庫返回該錯誤時,很難將其與導致問題的實體相匹配,因為 MSSQL 並沒有告訴您太多信息。 可以做這樣的事情:

catch (Exception ex)
{
    // if a "duplicate key" exception, extract the table name
    var match = Regex.Match(ex.Message, "duplicate key.* object '([^']*)'");
    if (match.Success)
    {
        var table = match.Groups[1].Value; // dbo.Customer
        var entityType = table.Split('.').Last(); // Customer
        throw new HttpException(409, "Duplicate key saving entity " + entityType, ex);
    }
    throw ex;
}

以便您獲得409 Conflict響應代碼和導致問題的實體的類型。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM