Я пытаюсь подключиться к своей базе данных, я новичок в репозитории, внедрение зависимостей. Я не мог подключиться к базе данных.
Как я могу решить эту проблему?
Это мой код:
Контроллер:
public ActionResult Create(FormCollection collection)
{
try
{
return RedirectToAction("Index");
}
catch
{
return View();
}
}
Репозиторий:
public UserMaster Add(UserMaster item)
{
using (SqlConnection sqlCon = new SqlConnection(connectionstring))
{
sqlCon.Open();
string query = "INSERT INTO Employee
VALUES (@ID, @Name, @City, @Address)";
for (int i = 0; i <= 100; i++)
{
SqlCommand sqlcmd = new SqlCommand(query, sqlCon);
sqlcmd.Parameters.AddWithValue(ID = i, Name = "newride", City = "newride", Address = "USA");
}
}
return item;
}





связь создается с использованием строка подключения и класса SqlConnection — похоже, это нормально в вашем коде.
НО: то, как вы пытаетесь получить значения вставлять, неверно — вам нужно использовать что-то вроде этого:
using (SqlConnection sqlCon = new SqlConnection(connectionstring))
{
sqlCon.Open();
// SPECIFY the column you insert into!
// Without the @ "query" is not recognized as a multiline string... that's why the PO is getting that VALUES does not exists in the current context...
string query = @"INSERT INTO Employee (ID, Name, City, Address)
VALUES (@ID, @Name, @City, @Address)";
for (int i = 0; i <= 100; i++)
{
SqlCommand sqlcmd = new SqlCommand(query, sqlCon);
// set the individual parameters, and AVOID "AddWithValue"
sqlcmd.Parameters.Add("@ID", SqlDbType.Int).Value = i;
sqlcmd.Parameters.Add("@Name", SqlDbType.VarChar, 100).Value = "newride";
sqlcmd.Parameters.Add("@City", SqlDbType.VarChar, 100).Value = "newride";
sqlcmd.Parameters.Add("@Address", SqlDbType.VarChar, 100).Value = "USA";
// and then *EXECUTE* the SqlCommand to actually RUN the INSERT
sqlcmd.ExecuteNonQuery();
}
}
большое спасибо, но в текущем контексте не существует значений ошибки броска строки Insert.
@Ravi просто добавьте знак @ перед кавычками строки, тогда компилятор будет знать, что вы создаете там многострочную строку
изменен знак @, но запись не вставляется в базу данных.
Если вы не можете на самом деле подключиться, вам может потребоваться опубликовать свой
ConnectionString(с деталями, соответствующим образом измененными для безопасности).