ASP.NET MVC verwendet gespeicherte Prozeduren, um Datenvorgänge stapelweise hinzuzufügen und zu ändern

高洛峰
Freigeben: 2017-02-20 17:11:45
Original
2464 Leute haben es durchsucht

In diesem Artikel wird hauptsächlich die Methode zum stapelweisen Hinzufügen und Ändern von Daten in ASP.NET MVC mithilfe gespeicherter Prozeduren vorgestellt. Er ist sehr gut und hat Referenzwert.

Verwenden von Entity Framework für Datenbanken Interaktion: Verwenden Sie direkt Lambda-Ausdrücke und Linq, um die Datenbank im Code zu betreiben, was Programmierern die Codierungszeit für den Datenbankzugriff erspart. Programmierer können sich direkt auf das Schreiben der Geschäftslogikschicht konzentrieren. Allerdings ist es aufwändiger, komplexere Tabellenbeziehungen abzufragen oder zu ändern. Die übliche Methode, die verwendet werden kann, besteht darin, EF zum Ausführen von SQL-Anweisungen oder „gespeicherten Prozeduren“ zu verwenden, insbesondere zum Ausführen komplexer Batch-Aufgaben. Natürlich können Sie auch ADO.NET am Ende von MVC verwenden, worauf ich nicht eingehen werde hier hinein. Wie macht man Chargen? Hier sprechen wir über die Verwendung gespeicherter Prozeduren zum stapelweisen Hinzufügen und Ändern von Daten unter EF.

Die Anforderungen lauten wie folgt: Sie müssen die Lieferaufgabenmenge der Produktkategorien stapelweise hinzufügen und ändern. Sie wird einmal im Monat aktualisiert und zu Beginn des Monats auf 0 zurückgesetzt werden im Formular angezeigt, d. h. die Hinzufügung und Änderung erfolgen alle auf einer Seite.

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

Idee: Das Frontend verwendet zunächst ein Formular, um die Kategorie dynamisch zu lesen, und verwendet Viewbag, um sie dynamisch hineinzuladen Wenn die Seite bereits vorhanden ist, wird die Anzahl der Aufgaben für den aktuellen Monat gelesen und auf dem Formular angezeigt, das geändert werden kann. Andernfalls wird die Anzahl der Aufgaben für den aktuellen Monat neu hinzugefügt. Beim Absenden des Formulars ist ein Problem aufgetreten. Ich habe mir eine Möglichkeit überlegt, ein verstecktes Feld mit dem Wert „Typ|Kategorienummer“ hinzuzufügen, um festzustellen, ob Es enthält Type. ist die Kategorienummer, dann verwenden Sie split('|')[1], um es in einer Schleife zu lesen.

Wie übergebe ich es an die Datenbank? Ich speichere die Daten in der Datentabelle, führe dann mit EF die gespeicherte Prozedur aus und übergebe die Datentabelle als Parameter zur Verarbeitung an die Datenbank.

Wie geht die Datenbank mit dieser Datentabelle um? Verwenden Sie benutzerdefinierte Datentypen, um

Codeschritte zu verarbeiten:

Codeaspekt

Controller-Anzeige dynamisch form

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();
  }
Nach dem Login kopieren

Zuerst wollte ich das Objekt direkt zurückgeben, aber die Vordergrunddurchquerung wurde nicht unterstützt, also habe ich eine neue Entitätsklasse ViewsModel erstellt.

Seite anzeigen

@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>
       }
Nach dem Login kopieren

Formular zur Einreichung von Controller-Beiträgen

[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();
  }
 }
Nach dem Login kopieren

An Datenbank senden Methode:

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;
   }
  }
Nach dem Login kopieren

Datenbankaspekt

Erstellen Sie zunächst wie folgt einen benutzerdefinierten Typ entsprechend der Situation

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

Sie können auch das SQL Server-Tool zum manuellen Erstellen verwenden eine neue

Die zweite besteht darin, eine gespeicherte Prozedur zu erstellen

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
Nach dem Login kopieren

Benutzerdefiniert Typen können wie Tabellen einzeln abgefragt werden. Benutzerdefinierte Funktionen sind nicht einfach zu debuggen. EF unterstützt keine benutzerdefinierten Funktionen beim direkten Aufruf gespeicherter Prozeduren.

Das Obige ist der vom Herausgeber eingeführte ASP.NET MVC-Batch-Vorgang zum Hinzufügen und Ändern von Daten. Ich hoffe, er wird Ihnen hilfreich sein. Wenn Sie Fragen haben, hinterlassen Sie mir bitte eine Nachricht Der Herausgeber wird allen umgehend antworten. Ich möchte mich auch bei Ihnen allen für Ihre Unterstützung der chinesischen PHP-Website bedanken!

Weitere Artikel im Zusammenhang mit ASP.NET MVC, das gespeicherte Prozeduren zum stapelweisen Hinzufügen und Ändern von Daten verwendet, finden Sie auf der chinesischen PHP-Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage