您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關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) { <div class="row" > <div class="col-md-4 text-right"><span class="red">*</span> @modelMarkets.Text </div> <div class="col-md-8 text-left"> <input name="text|@modelMarkets.ID" class="form-control" value="@modelMarkets.TaskNum" type="text" /> <input type="hidden" name="type|@modelMarkets.ID" value="type|@modelMarkets.ID" /><!--隱藏表單--> </div> </div> }
控制器 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 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如何使用存儲過程批量添加修改數據”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。