我正在尝试向我的GridView添加新值,稍后传递给Cache和DataSet以及基础SQL数据库。添加新行的ADO.NET增量ID
这是我的代码,但我不知道在行“dataRow [”ID“] =”上输入什么,如你所见。其他一切正常工作,其他值被添加到数据库,如果我只给“ID”任何不存在的数字。
protected void insertStudent_Click(object sender, EventArgs e)
{
DataSet dataSet = (DataSet)Cache["DATASET"];
//DataRow dataRow = dataSet.Tables["Students"].Rows.Find(e.Keys["ID"]);
dataSet.Tables["Students"].PrimaryKey = new DataColumn[] { dataSet.Tables["Students"].Columns["ID"] };
DataRow dataRow = dataSet.Tables["Students"].NewRow();
dataRow["ID"] =
dataRow["FirstName"] = ((TextBox)GridView1.FooterRow.FindControl("txtFirstName")).Text;
dataRow["LastName"] = ((TextBox)GridView1.FooterRow.FindControl("txtLastName")).Text;
dataRow["Gender"] = ((DropDownList)GridView1.FooterRow.FindControl("DropDownListGender")).SelectedValue;
dataRow["Course"] = ((DropDownList)GridView1.FooterRow.FindControl("DropDownListCourse")).SelectedValue;
dataRow["Grade"] = ((DropDownList)GridView1.FooterRow.FindControl("DropDownListGrade")).SelectedValue;
Cache.Insert("DATASET", dataSet, null, DateTime.Now.AddHours(24), System.Web.Caching.Cache.NoSlidingExpiration);
dataSet.Tables["Students"].Rows.Add(dataRow);
GridView1.DataSource = (DataSet)Cache["DATASET"];
GridView1.DataBind();
}
你不应该输入任何东西。通常数据库有ID字段的自动增量设置,所以新条目有一个唯一的ID =最后使用的ID + 1 – Andrei
如果我不添加任何东西,我会得到一个异常,“列ID不能为空”。关于如何在每个新条目上使用SQL来增加ID的任何想法?谢谢! –
这就是我正在谈论的,你应该设置数据库来处理这个问题。如果您正在使用SQL Server,请查看[this thread](例如http://stackoverflow.com/questions/10991894/auto-increment-primary-key-in-sql-server-management-studio-2012) – Andrei