ASP.NET MVC用存儲(chǔ)過程批量添加修改數(shù)據(jù)操作
用Entity Framework 進(jìn)行數(shù)據(jù)庫交互,在代碼里直接用lamda表達(dá)式和linq對(duì)數(shù)據(jù)庫操作,中間為程序員省去了數(shù)據(jù)庫訪問的代碼時(shí)間,程序員直接可以專注業(yè)務(wù)邏輯層的編寫。但是對(duì)于比較復(fù)雜的表關(guān)系關(guān)聯(lián)查詢或者修改就比較費(fèi)勁了。通常可以采用的方式是用EF執(zhí)行SQL語句或者“存儲(chǔ)過程”,特別是執(zhí)行復(fù)雜批量任務(wù),當(dāng)然也可以在MVC底層用ADO.NET,這里就不多說了。怎么做批量呢?這里講講在EF下用存儲(chǔ)過程批量添加修改數(shù)據(jù)。
需求是這樣的:需要批量添加修改產(chǎn)品類別的投放任務(wù)數(shù)額,每月更新一次,月初歸0,添加后會(huì)顯示在表單中,也就是添加修改都在一個(gè)頁面。
思路:前端先用表單把類別動(dòng)態(tài)讀取出來,用viewbag動(dòng)態(tài)加載到頁面,如果已經(jīng)有添加當(dāng)月任務(wù)數(shù),就讀取出來顯示到表單上,可以進(jìn)行修改,否則就是全新添加當(dāng)月任務(wù)數(shù)。提交表單的時(shí)候出現(xiàn)了個(gè)問題,怎么把類別編號(hào)post到后臺(tái),我想了一個(gè)辦法,那就是加一個(gè)隱藏域,值為"Type|類別編號(hào)",后臺(tái)取數(shù)據(jù)是判斷是否包含Type來判斷是否是類別編號(hào),然后用split('|')[1]循環(huán)讀取。
怎么傳遞到數(shù)據(jù)庫呢?我把數(shù)據(jù)存到datatable里面,然后用EF執(zhí)行存儲(chǔ)過程,把datatable當(dāng)著參數(shù)傳到數(shù)據(jù)庫處理。
數(shù)據(jù)庫怎么處理這個(gè)datatable呢?用自定義數(shù)據(jù)類型處理
代碼步驟:
代碼方面
控制器 顯示動(dòng)態(tài)表單
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()}); }//如果有數(shù)據(jù)關(guān)聯(lián)數(shù)據(jù) else { var rel2 = markeType.Select(s => new ViewsModel{ ID = s.ID, Text = s.Text, TaskNum="" }).ToList();//直接返回表單 ViewBag.datas = rel2; } return View(); }
開始想直接返回object,結(jié)果前臺(tái)遍歷不支持,故新建實(shí)體類ViewsModel。
View頁面
@foreach (var modelMarkets in ViewBag.datas) { <div class="row" style="margin-top:10px"> <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" style="width:50%" 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;//創(chuàng)建人或者修改人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]); }//循環(huán)分解表單 } 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);//調(diào)用方法 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(); } }
提交到數(shù)據(jù)庫方法:
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";//參數(shù)處理,貌似自定義函數(shù)必須加這個(gè)函數(shù)名稱 var rel = entity.Database.ExecuteSqlCommand("EXEC[dbo].[PR_MarketTaskAddorEdit] @CreatedUser,@tableMarketTask", p,p1);//ef執(zhí)行存儲(chǔ)過程 return rel > 0; } }
數(shù)據(jù)庫方面
首先根據(jù)情況建自定義類型,如下
-- Create the data type CREATE TYPE [dbo].[tableMarketTask] AS TABLE( [MKBTID] [varchar](50) NOT NULL,--投放類別 [TaskNum] [varchar](50) NOT NULL--投放任務(wù)數(shù)量 )
也可以用sql server 工具手動(dòng)新建
第二是建存儲(chǔ)過程
CREATE PROCEDURE PR_MarketTaskAddorEdit @CreatedUser INT, @tableMarketTask tableMarketTask readonly --自定義類型的參數(shù),必須加readonly。 AS DECLARE @TempCreatedUser INT IF EXISTS(SELECT TOP 1 * FROM MarketMonthTask T WHERE Months=MONTH(GETDATE()))--當(dāng)月存在的話就修改 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
自定義類型可以像表那樣自己查詢,很方便。自定義函數(shù)不容易調(diào)試。EF直接調(diào)用存儲(chǔ)過程也不支持自定義函數(shù)。
以上所述是小編給大家介紹的ASP.NET MVC用存儲(chǔ)過程批量添加修改數(shù)據(jù)操作,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- .net core EF Core調(diào)用存儲(chǔ)過程的方式
- C# Ado.net實(shí)現(xiàn)讀取SQLServer數(shù)據(jù)庫存儲(chǔ)過程列表及參數(shù)信息示例
- .net core2.0下使用Identity改用dapper存儲(chǔ)數(shù)據(jù)(實(shí)例講解)
- asp.net中調(diào)用存儲(chǔ)過程的方法
- asp.net中調(diào)用oracle存儲(chǔ)過程的方法
- VB.NET調(diào)用MySQL存儲(chǔ)過程并獲得返回值的方法
- .Net下二進(jìn)制形式的文件(圖片)的存儲(chǔ)與讀取詳細(xì)解析
- .NET中的字符串在內(nèi)存中的存儲(chǔ)方式
相關(guān)文章
.net Core連接MongoDB數(shù)據(jù)庫的步驟詳解
這篇文章主要給大家介紹了關(guān)于.net Core連接MongoDB數(shù)據(jù)庫步驟的相關(guān)資料,文中將實(shí)現(xiàn)的步驟一步步介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-02-02使用AjaxPro.Net框架實(shí)現(xiàn)在客戶端調(diào)用服務(wù)端的方法
AjaxPro.Net是一個(gè)優(yōu)秀的.net環(huán)境下的Ajax框架,用法很簡(jiǎn)單,可以查閱相關(guān)資料,本文檔是一個(gè)簡(jiǎn)單的實(shí)例講述使用AjaxPro的幾個(gè)關(guān)鍵點(diǎn)。2011-02-02MVC、MVP和MVVM分別是什么_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
MVC,MVP 和 MVVM分別是什么?MVC(Model-View-Controller)是最常見的軟件架構(gòu)之一,業(yè)界有著廣泛應(yīng)用。它本身很容易理解,但是要講清楚,它與衍生的 MVP 和 MVVM 架構(gòu)的區(qū)別就不容易了。2017-08-08asp.net 票據(jù)簡(jiǎn)單應(yīng)用
asp.net票據(jù)應(yīng)用實(shí)例代碼。2009-03-03.net驗(yàn)證碼的刷新或局部刷新的方法實(shí)例
.net驗(yàn)證碼的刷新或局部刷新的方法實(shí)例,下面是實(shí)例,需要的朋友可以參考一下2013-03-03ASP.NET 2.0服務(wù)器控件開發(fā)之復(fù)雜屬性
ASP.NET 2.0服務(wù)器控件開發(fā)之復(fù)雜屬性...2006-09-09ASP.NET2.0數(shù)據(jù)庫入門之SQL Server
ASP.NET2.0數(shù)據(jù)庫入門之SQL Server...2006-09-09IIS中ASP.NET連接SQL Server出錯(cuò)的解決方法
在IIS中運(yùn)行的ASP.NET應(yīng)用程序其所屬用戶名為ASPNET的特定用戶,其默認(rèn)權(quán)限是無法訪問SQL Server的,更不可能訪問ASP.NET應(yīng)用程序的數(shù)據(jù)庫了,因此要在IIS中訪問SQL Server就需要給ASPNET帳戶賦予相應(yīng)的權(quán)限.2010-03-03