ASP.NET MVC用預存程序大量新增修改資料操作

來源:互聯網
上載者:User
這篇文章主要介紹了ASP.NET MVC用預存程序大量新增修改資料的方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

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

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

思路:前端先用表單把類別動態讀取出來,用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('|')[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('操作成功!');window.location.href='/MarketTaskProgress/MarketTaskAdd';</script>";   else    ViewBag.js = "<script>alert('操作失敗!');window.location.href='/MarketTaskProgress/MarketTaskAdd';</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 typeCREATE 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用預存程序大量新增修改資料操作,希望對大家有所協助,如果大家有任何疑問請給我留言,小編會及時回複大家的。在此也非常感謝大家對topic.alibabacloud.com的支援!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.