-1

当我尝试使用上一步的 TextBox 控件的值时,我在 ASP.NET 向导中收到此错误。

错误:

    The INSERT statement conflicted with the FOREIGN KEY constraint "FK_Contact_Emp". 
The conflict occurred in database "KKSTech", table "dbo.Emp", column 'EmpID'.

访问不同步骤的控制值是否有问题?

4

2 回答 2

1

这是插入 dbo.Emp 表的第一个类

 public void InsertInfo()
        {
            String KKStech = @"Data Source=USER-PC\SQLEXPRESS;Initial Catalog=KKSTech;Integrated Security=True";
            SqlConnection conn = new SqlConnection(KKStech);
            String insertstring = @"insert into Emp (EmpID, FirstName, LastName, MiddleName, Mob1, Mob2, Phone, Email1, Email2, EmpDesc)
                            values (@EmpID,  @FirstName, @LastName, @MiddleName, @Mob1, @Mob2)";
            SqlCommand cmd = new SqlCommand(insertstring, conn);
            cmd.CommandText = insertstring;
            cmd.CommandType = CommandType.Text;

            try
            {
                conn.Open();
                cmd.Parameters.AddWithValue("@EmpID", TextBox1.Text);
                cmd.Parameters.AddWithValue("@FirstName", TextBox2.Text);
                cmd.Parameters.AddWithValue("@LastName", TextBox3.Text);
                cmd.Parameters.AddWithValue("@MiddleName", TextBox4.Text);
                cmd.Parameters.AddWithValue("@Mob1", TextBox5.Text);
                cmd.Parameters.AddWithValue("@Mob2", TextBox6.Text);
                cmd.ExecuteNonQuery();
            }

            finally
            {
                conn.Close();
            }
        }

这是我要插入到 EmpID 是 FK 的表中的那个

public void Insertaddress()
{
    String KKStech = @"Data Source=USER-PC\SQLEXPRESS;Initial Catalog=KKSTech;Integrated Security=True";
    SqlConnection conn = new SqlConnection(KKStech);
    String str = @"insert into Contact (Addressline1, Addressline2, CityID, EmpID)
                                values(@Addressline1, @Addressline2, @CityID, @EmpID)";
    SqlCommand cmd = new SqlCommand(str, conn);
    cmd.CommandText = str;
    cmd.CommandType = CommandType.Text;

    try
    {
        conn.Open();
        cmd.Parameters.AddWithValue("@Addressline1", TextBox15.Text);
        cmd.Parameters.AddWithValue("@Addressline2", TextBox17.Text);
        cmd.Parameters.AddWithValue("@CityID", DropDownList2.SelectedValue);
        cmd.Parameters.AddWithValue("@EmpID", TextBox1.Text);
        cmd.ExecuteNonQuery();
    }
    catch (System.Data.SqlClient.SqlException ex)
    {
        string msg = "Insert Error:";
        msg += ex.Message;
        throw new Exception(msg);
    }

    finally
    {
        conn.Close();
    }

}

那是我的问题。

于 2012-07-29T09:07:12.173 回答
0

外键确保它不能在该列中具有不在引用表的主键列中的值。

在您的情况下,您将插入EmpID到ie表contact的引用表中不存在的表中。EmpIDEmp

于 2012-07-29T06:29:52.490 回答