首頁  >  文章  >  後端開發  >  ASP.NET MVC以預存程序批次新增修改資料操作

ASP.NET MVC以預存程序批次新增修改資料操作

高洛峰
高洛峰原創
2017-02-20 17:11:452455瀏覽

這篇文章主要介紹了ASP.NET MVC用預存程序批量添加修改資料的方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

用Entity Framework 進行資料庫交互,在程式碼裡直接用lamda表達式和linq對資料庫操作,中間為程式設計師省去了資料庫存取的程式碼時間,程式設計師直接可以專注業務邏輯層的編寫。但是對於比較複雜的表關係關聯查詢或修改就比較費勁了。通常可以採用的方式是用EF執行SQL語句或“預存程序”,特別是執行複雜批量任務,當然也可以在MVC底層用ADO.NET,這裡就不多說了。怎麼做批量呢?這裡講講在EF下用預存程序批次新增修改資料。

     需求是這樣的:需要大量新增修改產品類別的投放任務金額,每月更新一次,月初歸0,新增後會顯示在表單中,也就是新增修改都在一個頁面。

ASP.NET MVC用存储过程批量添加修改数据操作

思路:前端先用表單把類別動態讀取出來,用viewbag動態載入到頁面,如果已經有加當月任務數,就讀取出來顯示到表單上,可以進行修改,否則就是全新新增當月任務數。提交表單的時候出現了個問題,怎麼把類別編號post到後台,我想了一個辦法,那就是加一個隱藏域,值為"Type|類別編號",後台取資料是判斷是否包含Type來判斷是否是類別編號,然後用split('|')[1]循環讀取。

        如何傳遞資料庫?我把資料存到datatable裡面,然後用EF執行預存程序,把datatable當著參數傳到資料庫處理。

        資料庫怎麼處理這個datatable?用自訂資料類型處理

代碼步驟:

    代碼方面

    控制器顯示動態表單

public ActionResult MarketTaskAdd()
  {
   var markeType = new MarketDataProvider().GetBTIDData().Where(a=>a.ID!="0");//读取类别
   var rel = new MarketTaskProgressProvider().GetMarketMonthTask();
   if (rel.Count() > 0)
   {
    ViewBag.datas = rel.Join(markeType, a => a.MKBTID, b => int.Parse(b.ID), (a, b) => new { a.MKBTID, b.ID,b.Text,a.TaskNum }).Select(s=>new ViewsModel { ID= s.MKBTID.ToString() ,Text=s.Text,TaskNum=s.TaskNum.ToString()}); }//如果有数据关联数据
   else
   {
    var rel2 = markeType.Select(s => new ViewsModel{ ID = s.ID, Text = s.Text, TaskNum="" }).ToList();//直接返回表单
    ViewBag.datas = rel2;
   }
   return View();
  }

 開始想直接回傳object,結果前台遍歷不支持,故新建實體類ViewsModel。

View頁面

@foreach (var modelMarkets in ViewBag.datas)
       {
        <p class="row" style="margin-top:10px">
         <p class="col-md-4 text-right"><span class="red">*</span> @modelMarkets.Text </p>
         <p class="col-md-8 text-left">
          <input name="text|@modelMarkets.ID" class="form-control" style="width:50%" value="@modelMarkets.TaskNum" type="text" />
          <input type="hidden" name="type|@modelMarkets.ID" value="type|@modelMarkets.ID" /><!--隐藏表单-->
         </p>
        </p>
       }

控制器  post提交表單

[HttpPost]
  public ActionResult MarketTaskAdd(string type)
  {
   var strform = Request.Form;
   int userId = adminUser!=null?adminUser.UserID:0;//创建人或者修改人ID
   DataTable dt = new DataTable();
   dt.Columns.Add("MKBTID",Type.GetType("System.Int32"));
   dt.Columns.Add("TaskNum", Type.GetType("System.Int32"));
   List<string> temp1 = new List<string>();
   List<string> temp2 = new List<string>();
   for (int i = 0; i < strform.Count; i++)
   {
    if (strform[i].Contains("type"))
    { temp1.Add(strform[i].Split(&#39;|&#39;)[1]); }
    else
    { temp2.Add(strform[i]); }//循环分解表单
   }
   for (int i = 0; i < temp1.Count; i++)
   {
    DataRow dr = dt.NewRow();
    dr[0] = temp1[i];
    dr[1] = temp2[i];
    dt.Rows.Add(dr);//批量添加到datatable
   }
   var rel = new MarketTaskProgressProvider().MarketTaskAddOrEdit(userId,dt);//调用方法
   if(rel)
     ViewBag.js = "<script>alert(&#39;操作成功!&#39;);window.location.href=&#39;/MarketTaskProgress/MarketTaskAdd&#39;;</script>";
   else
    ViewBag.js = "<script>alert(&#39;操作失败!&#39;);window.location.href=&#39;/MarketTaskProgress/MarketTaskAdd&#39;;</script>";
   List<ViewsModel> listTemp = new List<ViewsModel>();
   listTemp.Add(new ViewsModel
   {
    ID = "",
    Text = "",
    TaskNum = ""
   });
   ViewBag.datas = listTemp;
   return View();
  }
 }

提交到資料庫方法:

public bool MarketTaskAddOrEdit(int userId,DataTable dt)
  {
   using (DssEntity entity = new DssEntity())//不推荐用using
   {
    SqlParameter p = new SqlParameter("@CreatedUser",DbType.Int32);
    p.Value = userId;
    SqlParameter p1 = new SqlParameter("@tableMarketTask",DbType.Object);
    p1.Value = dt;
    p1.TypeName = "tableMarketTask";//参数处理,貌似自定义函数必须加这个函数名称
    var rel = entity.Database.ExecuteSqlCommand("EXEC[dbo].[PR_MarketTaskAddorEdit] @CreatedUser,@tableMarketTask", p,p1);//ef执行存储过程
    return rel > 0;
   }
  }

資料庫方面

先依照情況建立自訂類型,如下

-- Create the data type
CREATE TYPE [dbo].[tableMarketTask] AS TABLE(
 [MKBTID] [varchar](50) NOT NULL,--投放类别
 [TaskNum] [varchar](50) NOT NULL--投放任务数量
)

  也可以用sql server 工具手動新建

第二是建置儲存流程

CREATE PROCEDURE PR_MarketTaskAddorEdit
 @CreatedUser INT,
 @tableMarketTask tableMarketTask readonly --自定义类型的参数,必须加readonly。
AS
 DECLARE @TempCreatedUser INT
 IF EXISTS(SELECT TOP 1 * FROM MarketMonthTask T WHERE Months=MONTH(GETDATE()))--当月存在的话就修改
 BEGIN
  SELECT TOP 1 @TempCreatedUser=CreatedUser FROM MarketMonthTask T WHERE Months=MONTH(GETDATE())
  DELETE FROM MarketMonthTask WHERE Months=MONTH(GETDATE())
  INSERT INTO MarketMonthTask(MKBTID,TaskNum,Months,UpdateUser,CreatedUser) SELECT MKBTID,TaskNum,MONTH(GETDATE()),@CreatedUser,@TempCreatedUser FROM @tableMarketTask
 END
 ELSE--或者直接插入
 BEGIN
  INSERT INTO MarketMonthTask(MKBTID,TaskNum,Months,CreatedUser) SELECT MKBTID,TaskNum,MONTH(GETDATE()),@CreatedUser FROM @tableMarketTask
 END

自訂類型可以像表一樣自己查詢,很方便。自訂函數不容易調試。 EF直接呼叫預存程序也不支援自訂函數。

以上所述是小編給大家介紹的ASP.NET MVC用預存程序批量添加修改資料操作,希望對大家有幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對PHP中文網的支持!

更多ASP.NET MVC以預存程序批次新增修改資料操作相關文章請關注PHP中文網!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn