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.
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(); }
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> }
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('|')[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(); } }
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; } }
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--投放任务数量 )
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
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!