从数据库中获取数据并分配它

本文关键字:分配 数据 获取 数据库 | 更新日期: 2023-09-27 17:57:23

>我已经从数据库中分配了检索到的数据(ChancesLeft),并用创建的变量分配它。但是当我检查控制器中创建的变量(已经分配给数据库中检索到的数据(ChancesLeft))时,创建的变量的值始终为 0,即使我已经调用了该检索函数。但是,当我签入检索函数所在的类时,创建的变量的值不是 0,而是遵循检索到的数据的值 ( ChancesLeft )。

我的问题是,如何将值从类传递到控制器?这样我就可以使用它了?

代码(系统管理器):

public void RetrieveChancesLeft(string Name)
        {
            MyModel context = new MyModel();
            using (SqlConnection conn = new SqlConnection(connectionString))
            {
                string query = "SELECT [Name], [ChancesLeft] FROM [Credentials] WHERE [Name] = @Name";
                conn.Open();
                using (SqlCommand cmd = new SqlCommand(query, conn))
                {
                    cmd.Parameters.Add("@Name", SqlDbType.NVarChar);
                    cmd.Parameters["@Name"].Value = Name;
                    using (SqlDataReader reader = cmd.ExecuteReader())
                    {
                        while (reader.Read())
                        {
                            context.Chances = Convert.ToInt32(reader["ChancesLeft"]);
                        }
                    }
                }
                conn.Close();
            }
        }

控制器:

 SystemManager _sm = new SystemManager();
 [HttpGet]
    public ActionResult Index()
    {
        return View();
    }
 [HttpPost]
    public ActionResult Index(MyModel context, string Name)
    {
        _sm.RetrieveChancesLeft(Name);
        if (context.Chances > 0)
        {
            return RedirectToAction("About", "Home");
        }
        else
        {
            return RedirectToAction("GetStarted", "Home");
        }
    }

问题是,每当我运行程序并输入Name它总是重定向到GetStarted视图,因此这意味着context.Chances始终为 0,即使数据库中的ChancesLeft不是 0。

从数据库中获取数据并分配它

RetrieveChancesLeft 函数应将本地上下文对象存储在 SystemManager 对象中以供检索或将上下文返回给调用方。您可以更改 RetrieveChancesLeft 函数的返回类型,以将对象传递给控制器:

public MyModel RetrieveChancesLeft(string Name)
    {
        MyModel context = new MyModel();
        using (SqlConnection conn = new SqlConnection(connectionString))
        {
            string query = "SELECT [Name], [ChancesLeft] FROM [Credentials] WHERE [Name] = @Name";
            conn.Open();
            using (SqlCommand cmd = new SqlCommand(query, conn))
            {
                cmd.Parameters.Add("@Name", SqlDbType.NVarChar);
                cmd.Parameters["@Name"].Value = Name;
                using (SqlDataReader reader = cmd.ExecuteReader())
                {
                    while (reader.Read())
                    {
                        context.Chances = Convert.ToInt32(reader["ChancesLeft"]);
                    }
                }
            }
            conn.Close();
        }
        return context;
    }

而您的控制器:

    SystemManager _sm = new SystemManager();
 [HttpGet]
    public ActionResult Index()
    {
        return View();
    }
 [HttpPost]
    public ActionResult Index(MyModel context, string Name)
    {
        context = _sm.RetrieveChancesLeft(Name);
        if (context.Chances > 0)
        {
            return RedirectToAction("About", "Home");
        }
        else
        {
            return RedirectToAction("GetStarted", "Home");
        }
    }