Мои команды запроса не вставляют значения в таблицу.
Я дважды проверил, чтобы убедиться, что я правильно подключен к SQL Server. Я не получаю ошибок при запуске кода, однако когда я выполняю функцию без запроса, она всегда возвращает 0, что означает, что мой запрос не был успешным. Я посмотрел на каждом ресурсе. Мой синтаксис кажется правильным, но я не уверен.
Form1.cs (пользовательский интерфейс для кнопки добавления данных моего приложения)
public partial class Storage : Form
{
storageMLGW s = new storageMLGW();
public Storage()
{
InitializeComponent();
}
private void Button1_Click(object sender, EventArgs e)
{
s.Manufacturer = textBoxManufacturer.Text;
s.Model = textBoxModel.Text;
s.SerialNo = textBoxSerialNo.Text;
s.Item_Type = textBoxItemType.Text;
s.Building = textBoxBuilding.Text;
s.RoomNo = textBoxRoomNo.Text;
s.FaxNo = textBoxFaxNo.Text;
s.IP_Address = textBoxIPAddress.Text;
s.UserAssigned = textBoxUserAssigned.Text;
s.AreaName = textBoxAreaName.Text;
s.AreaNo = textBoxAreaNo.Text;
bool isSuccess = s.Insert(s);
if (isSuccess == true)
{
MessageBox.Show("New Product successfully inserted.");
}
else
{
MessageBox.Show("Failed to add new product. Try again.");
}
}
}
storageMLGW.cs
class storage MLGW
{
//Getters and setters
public int ProductID { get; set; }
public string Manufacturer { get; set; }
public string Model { get; set; }
public string SerialNo { get; set; }
public string Item_Type { get; set; }
public string Building { get; set; }
public string RoomNo { get; set; }
public string FaxNo { get; set; }
public string IP_Address { get; set; }
public string UserAssigned { get; set; }
public string AreaName { get; set; }
public string AreaNo { get; set; }
static string myconnstring = ConfigurationManager.ConnectionStrings["connstring"].ConnectionString;
public bool Insert(storageMLGW s)
{
bool isSuccess = false;
SqlConnection conn = new SqlConnection(myconnstring);
try
{
string sql = "INSERT INTO storage_mlgw (Manufacturer, Model, SerialNo, Item_Type, Building, RoomNo, FaxNo, IP_Address, UserAssigned, AreaName, AreaNo) " +
"VALUES(@Manufacturer, @Model, @SerialNo, @Item_Type, @Building, @RoomNo, @FaxNo, @IP_Address, @UserAssigned, @AreaName, @AreaNo)";
SqlCommand cmd = new SqlCommand(sql, conn);
cmd.Parameters.Add("@Manufacturer", SqlDbType.VarChar, 50);
cmd.Parameters.Add("@Model", SqlDbType.VarChar, 50);
cmd.Parameters.Add("@SerialNo", SqlDbType.VarChar, 50);
cmd.Parameters.Add("@Item_Type", SqlDbType.VarChar, 50);
cmd.Parameters.Add("@Building", SqlDbType.VarChar, 50);
cmd.Parameters.Add("@RoomNo", SqlDbType.VarChar, 50);
cmd.Parameters.Add("@FaxNo", SqlDbType.VarChar, 50);
cmd.Parameters.Add("@IP_Address", SqlDbType.VarChar, 50);
cmd.Parameters.Add("@UserAssigned", SqlDbType.VarChar, 50);
cmd.Parameters.Add("@AreaName", SqlDbType.VarChar, 50);
cmd.Parameters.Add("@AreaNo", SqlDbType.VarChar, 50);
cmd.Parameters["@Manufacturer"].Value = s.Manufacturer;
cmd.Parameters["@Model"].Value = s.Model;
cmd.Parameters["@SerialNo"].Value = s.SerialNo;
cmd.Parameters["@Item_Type"].Value = s.Item_Type;
cmd.Parameters["@Building"].Value = s.Building;
cmd.Parameters["@RoomNo"].Value = s.RoomNo;
cmd.Parameters["@FaxNo"].Value = s.FaxNo;
cmd.Parameters["@IP_Address"].Value = s.IP_Address;
cmd.Parameters["@UserAssigned"].Value = s.UserAssigned;
cmd.Parameters["@AreaName"].Value = s.AreaName;
cmd.Parameters["@AreaNo"].Value = s.AreaNo;
conn.Open();
int rows = cmd.ExecuteNonQuery();
if (rows > 0)
{
isSuccess = true;
}
else
{
isSuccess = false;
}
catch(Exception ex)
{
}
finally
{
conn.Close();
}
return isSuccess;
}
}
Я ожидаю, что вывод вернет true и напечатает окно сообщения "продукт был успешно добавлен". Вместо этого метод Insert возвращает false.