我有一个表单,用户可以在其中插入、查看和更新数据。数据插入只进行一次,然后可以进行多次更新。默认情况下,如果数据存在于数据库中,用户将能够查看数据。
我试过了,但它没有插入数据库。然后假设数据库中存在数据,当用户想要更新记录时,它会抛出一个错误——DataReader 已打开。
   private void display_Emp()
    {
        try
        {
            using (sqlCon = new SqlConnection(ConfigurationManager.ConnectionStrings["Connection"].ConnectionString))
            {
                sqlCon.Open(); 
                SqlDataAdapter da = new SqlDataAdapter("SELECT * FROM Employee", sqlCon);
                DataSet ds = new DataSet("Employee");
                da.Fill(ds, "Employee");
                int x = 0;
                for (x = 0; x < ds.Tables[0].Rows.Count; x++)
                {
                    txtID.Text = ds.Tables[0].Rows[x][1].ToString();
                    txtEmpName.Text = ds.Tables[0].Rows[x][2].ToString();
                }
            }
        }
        catch(Exception exx) {
            MessageBox.Show(exx.Message);
        }
        finally {
            sqlCon.Close();
        }
    }
private void btnSave_Click(object sender, EventArgs e)
{
    try 
    {
        using (sqlCon = new SqlConnection(ConfigurationManager.ConnectionStrings["Connection"].ConnectionString))
        {
            sqlCon.Open();
            SqlCommand com = new SqlCommand("SELECT * FROM Employee", sqlCon);
            read = com.ExecuteReader(); 
            while (read.Read())
            {                     
                if (read.HasRows) 
                {
                    SqlCommand update = new SqlCommand("UPDATE Employee SET EmpID = '" + txtID.Text + "' , EmpName = '" + txtEmpName.Text + "', sqlCon);
                    update.ExecuteNonQuery();
                    MessageBox.Show("Employee details updated!", "Employee", MessageBoxButtons.OK, MessageBoxIcon.Information);
                }
                else
                {
                    SqlCommand comm = new SqlCommand("INSERT INTO Employee(EmpID, EmpName) VALUES ('" + txtID.Text + "','" + txtEmpName.Text + "')", sqlCon);
                    comm.ExecuteNonQuery();
                    MessageBox.Show("Employee details saved!", "Employee", MessageBoxButtons.OK, MessageBoxIcon.Information);
                }
            }
        }
    }
    catch(Exception ex) 
    {
       MessageBox.Show(ex.Message);
    }
    finally 
    {
        read.Close();
        sqlCon.Close();
    }                   
}
编辑:
表:- Deepz(ID int PK,Goodname varchar(50))
DECLARE @ID int 
DECLARE @Goodname varchar(50) 
    MERGE Deepz t
    USING (SELECT @ID[ID], @Goodname[Goodname]) s 
        ON (t.ID = s.ID)
    WHEN MATCHED THEN
        UPDATE
        SET t.Goodname = @Goodname
    WHEN NOT MATCHED THEN
        INSERT (ID, Goodname)
        VALUES (@ID, @Goodname);
错误:
Msg 102, Level 15, State 1, Line 1
Incorrect syntax near 't'.
Msg 137, Level 15, State 2, Line 2
Must declare the scalar variable "@ID".