ASP.NET MVC - 在不同的视图/控制器中调用相同的存储过程
创始人
2024-09-16 09:00:54
0

在ASP.NET MVC中,可以使用ADO.NET来调用存储过程并在不同的视图或控制器中重复使用。

首先,在项目中创建一个存储过程。假设我们有一个名为GetProducts的存储过程,它返回所有产品的列表。存储过程的示例如下:

CREATE PROCEDURE GetProducts
AS
BEGIN
    SELECT * FROM Products
END

接下来,在数据访问层中创建一个DataAccess类来处理与数据库的交互。在这个类中,可以编写一个方法来调用存储过程并返回结果。示例代码如下:

public class DataAccess
{
    private string connectionString = "your_connection_string_here";

    public List GetProducts()
    {
        List products = new List();

        using (SqlConnection connection = new SqlConnection(connectionString))
        {
            SqlCommand command = new SqlCommand("GetProducts", connection);
            command.CommandType = CommandType.StoredProcedure;

            connection.Open();

            SqlDataReader reader = command.ExecuteReader();

            while (reader.Read())
            {
                Product product = new Product();
                product.Id = Convert.ToInt32(reader["Id"]);
                product.Name = reader["Name"].ToString();
                product.Price = Convert.ToDecimal(reader["Price"]);

                products.Add(product);
            }

            reader.Close();
        }

        return products;
    }
}

上述代码创建了一个名为GetProducts的方法,它通过执行名为GetProducts的存储过程来获取产品列表,并将结果转换为Product对象的列表。

接下来,在需要调用存储过程的控制器中实例化DataAccess类,并调用GetProducts方法。示例代码如下:

public class HomeController : Controller
{
    private DataAccess dataAccess = new DataAccess();

    public ActionResult Index()
    {
        List products = dataAccess.GetProducts();

        return View(products);
    }
}

在上述示例中,Index方法通过实例化DataAccess类并调用GetProducts方法来获取产品列表,并将其传递给Index视图。

最后,在视图中循环遍历产品列表并显示相关信息。示例代码如下:

@model List

@foreach (var product in Model)
{
    

@product.Name - @product.Price

}

上述示例中,@model List指定了视图的模型类型,并通过循环遍历产品列表来显示每个产品的名称和价格。

通过上述步骤,您可以在不同的视图或控制器中调用相同的存储过程,并重复使用代码。

相关内容

热门资讯

智星德州菠萝有挂吗!德州最新辅... 智星德州菠萝有挂吗!德州最新辅助器,(wopoker)好像真的有挂(详细辅助详细教程)1、这是跨平台...
辅助透视(德扑ai智能)德州a... 辅助透视(德扑ai智能)德州ai辅助代理(详细辅助玩家教你)原本存在有挂1、下载好辅助软件之后点击打...
德扑之星辅助器购买!wpk德州... 大家肯定在之前德扑之星辅助器购买或者德扑之星辅助器购买中玩过德扑之星辅助器购买!wpk德州透视辅助,...
透视软件(智星德州菠萝有挂吗)... 一、简介了解软件请加微:136704302是一款在线扑克游戏平台,玩家可以在平台上进行多人在线扑克游...
aapoker透明挂!云扑克内... 此外,数据分析德州(aapoker透明挂)辅助神器app还具备辅助透视行为开挂功能,通过对客户aap...
透视工具(aapoker有外挂... 1、透视工具(aapoker有外挂)wepoke软件透明挂视频(详细辅助必备教程)本来是有挂;代表性...
WePoKe透视挂!德州app... WePoKe透视挂!德州app辅助工具,(aapokEr)好像有挂(详细辅助玩家教程)是一款可以让一...
透视安装(wpk ai辅助)w... 透视安装(wpk ai辅助)wepoke最新下载地址(详细辅助解说技巧)从前存在有挂1、ai机器人多...
aapoker透明挂!wepo... aapoker透明挂!wepoke德扑之星,(AApoker)一贯有挂(详细辅助透明挂教程);精心打...
透视讲解(wepoke辅助技巧... 透视讲解(wepoke辅助技巧)德扑分析软件(详细辅助存在挂教程)原先是真的有挂1、快速入门:当你通...