从数据库中获取数据并分配它
本文关键字:分配 数据 获取 数据库 | 更新日期: 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");
}
}