Maison > Article > développement back-end > ASP.NET MVC utilise des procédures stockées pour ajouter et modifier des opérations de données par lots
Cet article présente principalement la méthode d'ajout et de modification de données par lots dans ASP.NET MVC à l'aide de procédures stockées. Il est très bon et a une valeur de référence. Les amis dans le besoin peuvent se référer à
Utilisation d'Entity Framework pour la base de données. Interaction.Utilisez directement les expressions lambda et Linq pour faire fonctionner la base de données dans le code, ce qui permet aux programmeurs de gagner du temps de codage pour accéder à la base de données. Les programmeurs peuvent se concentrer directement sur l'écriture de la couche de logique métier. Cependant, il est plus laborieux d'interroger ou de modifier des relations entre tables plus complexes. La méthode habituelle qui peut être utilisée consiste à utiliser EF pour exécuter des instructions SQL ou des "procédures stockées", notamment pour exécuter des tâches par lots complexes. Bien sûr, vous pouvez également utiliser ADO.NET en bas de MVC, ce que je n'aborderai pas. ici. Comment faire des lots ? Nous parlons ici de l'utilisation de procédures stockées pour ajouter et modifier des données par lots sous EF.
Les exigences sont les suivantes : vous devez ajouter et modifier le montant de la tâche de livraison des catégories de produits par lots. Il est mis à jour une fois par mois et se réinitialise à 0 au début du mois. être affiché dans le formulaire, c'est-à-dire que l'ajout et la modification se font tous sur une seule page.
Idée : Le front-end utilise d'abord un formulaire pour lire dynamiquement la catégorie, et utilise viewbag pour la charger dynamiquement dans la page. S'il y en a déjà. Après avoir ajouté le nombre de tâches pour le mois en cours, il sera lu et affiché sur le formulaire, qui pourra être modifié. Sinon, le nombre de tâches pour le mois en cours sera nouvellement ajouté. Lors de la soumission du formulaire, un problème est survenu. Comment publier le numéro de catégorie sur le backend ? J'ai pensé à un moyen, c'est-à-dire d'ajouter un champ caché avec la valeur "Type|Numéro de catégorie". il contient Type. est le numéro de catégorie, puis utilisez split('|')[1] pour le lire en boucle.
Comment le transmettre à la base de données ? J'enregistre les données dans le datatable, puis j'utilise EF pour exécuter la procédure stockée et je transmets le datatable à la base de données comme paramètres de traitement.
Comment la base de données gère-t-elle cette table de données ? Utiliser des types de données personnalisés pour traiter
Étapes du code :
Aspect du code
Affichage du contrôleur Dynamique 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(); }
Au début, je voulais renvoyer l'objet directement, mais la traversée au premier plan n'était pas prise en charge, j'ai donc créé une nouvelle classe d'entité ViewsModel.
Afficher la page
@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> }
Formulaire de soumission de poste de contrôleur
[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(); } }
Méthode de soumission à la base de données :
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; } }
Aspect de la base de données
Créez d'abord un type personnalisé en fonction de la situation, comme suit
-- Create the data type CREATE TYPE [dbo].[tableMarketTask] AS TABLE( [MKBTID] [varchar](50) NOT NULL,--投放类别 [TaskNum] [varchar](50) NOT NULL--投放任务数量 )
Vous pouvez également utiliser l'outil serveur SQL pour créer manuellement un nouveau
La seconde consiste à créer une procédure stockée
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
Personnalisée les types peuvent être interrogés par eux-mêmes comme des tables. Les fonctions personnalisées ne sont pas faciles à déboguer. EF ne prend pas en charge les fonctions personnalisées lors de l’appel direct de procédures stockées.
Ce qui précède concerne les opérations d'ajout et de modification de données par lots d'ASP.NET MVC à l'aide de procédures stockées introduites par l'éditeur. J'espère que cela vous sera utile. Si vous avez des questions, veuillez me laisser un message et. l'éditeur répondra rapidement à tout le monde. Je voudrais également vous remercier tous pour votre soutien au site Web PHP chinois !
Pour plus d'articles liés aux opérations d'ajout et de modification de données par lots ASP.NET MVC à l'aide de procédures stockées, veuillez faire attention au site Web PHP chinois !