通过名单>> SQL 存储过程:更好的方法
正如经常遇到的那样,将多个项目加载到特定数据库记录可能会带来挑战。考虑这样一个场景:网页允许用户选择报告项目,并且这些项目对应于数据库中的记录(分别为报告表和项目表)。提交后,数据库会更新添加到 ReportItems 表中的所选项目(ReportId、ItemId)。
传统上,处理此问题涉及 SQL 命令和存储过程。然而,SQL Server 2008 中表值参数 (TVP) 的引入提供了一个卓越的解决方案。
表值参数
TVP 允许传递项目列表将存储过程作为单个数据集,消除了字符串连接和重复参数插入的需要。相反,TVP 被定义为表类型并在存储过程中接收。
代码实现
在您的代码中,可以修改 AddItemsToReport 方法以使用TVP如下:
public void AddItemsToReport(string connStr, int Id, List<int> itemList) { Database db = DatabaseFactory.CreateDatabase(connStr); string sqlCommand = "AddItemsToReport"; DbCommand dbCommand = db.GetStoredProcCommand(sqlCommand); // Create TVP DataTable DataTable itemTable = new DataTable("Items"); itemTable.Columns.Add("ItemId", typeof(int)); // Fill TVP DataTable foreach (int item in itemList) itemTable.Rows.Add(item); // Add TVP parameter db.AddParameter(dbCommand, "Items", DbType.Object, itemTable); db.ExecuteNonQuery(dbCommand); }
在存储中过程:
INSERT INTO ReportItem (ReportId, ItemId) SELECT ReportId, ItemId FROM @Items
优点
TVP 与之前的方法相比有几个优点:
兼容性注意事项
请注意,TVP 支持SQL Server 2008 仅限于该版本及更高版本。如果处理早期版本的 SQL Server,可能需要考虑替代解决方案,例如 XML 参数或用户定义函数。
以上是表值参数如何改进向 SQL 存储过程传递列表?的详细内容。更多信息请关注PHP中文网其他相关文章!