Есть ли проблема с моей командой sql query INSERT INTO? - PullRequest
0 голосов
/ 27 июня 2019

Мои команды запроса не вставляют значения в таблицу.

Я дважды проверил, чтобы убедиться, что я правильно подключен к 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.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...