1

我的系统没有出现任何错误,但是当我尝试添加时,tblHardware 没有添加任何内容。这是我的代码。

private void btnTilfoj_Click(object sender, EventArgs e)
{
    conn = new SqlConnection(connectionstring);
    conn.Open();
    commandstring = "INSERT INTO tblItUdstyr([HardwareType], [KobsDato], [SerieNr]) VALUES(@HardwareType, @KobsDato, @SerieNr)";
    comm = new SqlCommand(commandstring, conn);

    comm.Parameters.Add("@HardwareType", SqlDbType.VarChar);
    comm.Parameters["@HardwareType"].Value = cbHardware.Text.ToString();

    comm.Parameters.Add("@KobsDato", SqlDbType.Date);
    comm.Parameters["@KobsDato"].Value = dtpKobsDato.Value;

    comm.Parameters.Add("@SerieNr", SqlDbType.VarChar);
    comm.Parameters["@SerieNr"].Value = txtSerienr.Text.ToString();
}
4

2 回答 2

2

你需要运行这个:

comm.ExecuteNonQuery();

但是,我建议您做一些其他的事情:

using (SqlConnection conn = new SqlConnection(connectionstring))
{
    conn.Open();

    commandstring = "INSERT INTO tblItUdstyr([HardwareType], [KobsDato], [SerieNr]) VALUES(@HardwareType, @KobsDato, @SerieNr)";
    comm = new SqlCommand(commandstring, conn);

    comm.Parameters.AddWithValue("@HardwareType", cbHardware.Text.ToString());
    comm.Parameters.AddWithValue("@KobsDato", dtpKobsDato.Value);
    comm.Parameters.AddWithValue("@SerieNr", txtSerienr.Text.ToString());

    comm.ExecuteNonQuery();
}

我添加了 ,using因为这将正确关闭并处理SqlConnection. 此外,我添加了该AddWithValue方法,因为它在类型匹配方面更精简且更准确。

于 2013-05-20T19:22:56.427 回答
2

每个命令都应该以某种方式执行。
您的代码很好,但缺少最后一次调用

使用这样的东西

 commandstring = "INSERT INTO tblItUdstyr([HardwareType], [KobsDato], [SerieNr]) " + 
                 "VALUES(@HardwareType, @KobsDato, @SerieNr)";
using(conn = new SqlConnection(connectionstring))
using(comm = new SqlCommand(commandstring, conn))
{
     conn.Open();
     comm.Parameters.Add("@HardwareType", SqlDbType.VarChar);
     comm.Parameters["@HardwareType"].Value = cbHardware.Text.ToString();
     comm.Parameters.Add("@KobsDato", SqlDbType.Date);
     comm.Parameters["@KobsDato"].Value = dtpKobsDato.Value;
     comm.Parameters.Add("@SerieNr", SqlDbType.VarChar);
     comm.Parameters["@SerieNr"].Value = txtSerienr.Text.ToString();
     comm.ExecuteNonQuery();  //This is the call that sends your data to the database
}

请注意我如何将您的所有代码放在using 语句中。这将在您完成后强制关闭和处置 SqlCommand 和 SqlConnection。也有例外的情况

于 2013-05-20T19:25:03.407 回答