溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

ASP.NET MVC如何使用存儲(chǔ)過(guò)程批量添加修改數(shù)據(jù)

發(fā)布時(shí)間:2021-07-23 09:16:45 來(lái)源:億速云 閱讀:296 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章給大家分享的是有關(guān)ASP.NET MVC如何使用存儲(chǔ)過(guò)程批量添加修改數(shù)據(jù)的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

用Entity Framework 進(jìn)行數(shù)據(jù)庫(kù)交互,在代碼里直接用lamda表達(dá)式和linq對(duì)數(shù)據(jù)庫(kù)操作,中間為程序員省去了數(shù)據(jù)庫(kù)訪問(wèn)的代碼時(shí)間,程序員直接可以專注業(yè)務(wù)邏輯層的編寫。但是對(duì)于比較復(fù)雜的表關(guān)系關(guān)聯(lián)查詢或者修改就比較費(fèi)勁了。通常可以采用的方式是用EF執(zhí)行SQL語(yǔ)句或者“存儲(chǔ)過(guò)程”,特別是執(zhí)行復(fù)雜批量任務(wù),當(dāng)然也可以在MVC底層用ADO.NET,這里就不多說(shuō)了。怎么做批量呢?這里講講在EF下用存儲(chǔ)過(guò)程批量添加修改數(shù)據(jù)。

     需求是這樣的:需要批量添加修改產(chǎn)品類別的投放任務(wù)數(shù)額,每月更新一次,月初歸0,添加后會(huì)顯示在表單中,也就是添加修改都在一個(gè)頁(yè)面。

ASP.NET MVC如何使用存儲(chǔ)過(guò)程批量添加修改數(shù)據(jù)

思路:前端先用表單把類別動(dòng)態(tài)讀取出來(lái),用viewbag動(dòng)態(tài)加載到頁(yè)面,如果已經(jīng)有添加當(dāng)月任務(wù)數(shù),就讀取出來(lái)顯示到表單上,可以進(jìn)行修改,否則就是全新添加當(dāng)月任務(wù)數(shù)。提交表單的時(shí)候出現(xiàn)了個(gè)問(wèn)題,怎么把類別編號(hào)post到后臺(tái),我想了一個(gè)辦法,那就是加一個(gè)隱藏域,值為"Type|類別編號(hào)",后臺(tái)取數(shù)據(jù)是判斷是否包含Type來(lái)判斷是否是類別編號(hào),然后用split('|')[1]循環(huán)讀取。

        怎么傳遞到數(shù)據(jù)庫(kù)呢?我把數(shù)據(jù)存到datatable里面,然后用EF執(zhí)行存儲(chǔ)過(guò)程,把datatable當(dāng)著參數(shù)傳到數(shù)據(jù)庫(kù)處理。

        數(shù)據(jù)庫(kù)怎么處理這個(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();
  }

 開(kāi)始想直接返回object,結(jié)果前臺(tái)遍歷不支持,故新建實(shí)體類ViewsModel。

View頁(yè)面

@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;//創(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ù)庫(kù)方法:

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ǔ)過(guò)程
    return rel > 0;
   }
  }

數(shù)據(jù)庫(kù)方面

首先根據(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ǔ)過(guò)程

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ǔ)過(guò)程也不支持自定義函數(shù)。

感謝各位的閱讀!關(guān)于“ASP.NET MVC如何使用存儲(chǔ)過(guò)程批量添加修改數(shù)據(jù)”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI