对于主键是自动递增字段的表用SqlCommandBuilder如何增删改数据表?

blueseasky 2003-07-24 05:31:02
在WinFrom下的DataGrid中进行数据的增删改操作,最后想用SqlCommandBuilder更新数据库,怎么写?
...全文
171 14 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
qimini 2003-08-04
  • 打赏
  • 举报
回复
看看這段代碼,也許對你有幫助

dsADP.InsertCommand = GetInsertCommand();
dsADP.InsertCommand.UpdatedRowSource=System.Data.UpdateRowSource.FirstReturnedRecord;

if ( Task.HasErrors )
{
Task.Tables[TaskData.TASK_TABLE].GetErrors()[0].ClearErrors();
return false;
}
else
{
Task.Tables[TaskData.TASK_TABLE].Rows[0][0]=dsCommand.InsertCommand.Parameters[TaskID].Value;
Task.AcceptChanges();
return true;
}
lufly2000 2003-08-04
  • 打赏
  • 举报
回复
to qimini(循序渐进)

除非你要Insert操作后自动递增字段的返回值,即便如此自增字段也被定义为输出参数


我就是这个意思,在insert后返回自动递增的字段的值,定义为输出参数写入到dataset刚刚添加的行中,就像我刚才说的,不然无法删除或修改此纪录,因为dataset中这条记录的主键字段是空的。



欢迎讨论。
lufly2000 2003-08-04
  • 打赏
  • 举报
回复
to blueseasky(蔚蓝海天)

没插入数据库就不用@@IDENTITY啊,数据库中的自动递增字段确实是不能指定的,但我的方法是在将一条记录插入到数据库中后,将数据库中刚刚已经自动递增的字段返回并且填写在dataset中新增加的那条记录上,要不你如何删除或者修改刚刚增加的记录?删除或者修改记录是要主键来确定的,如果不返回自动递增的字段在删除或修改刚刚增加的记录时就会出现并发冲突。
bdm303 2003-08-03
  • 打赏
  • 举报
回复
还是没有说清楚这个CommandBuilder到底应该怎么用。
qimini 2003-07-25
  • 打赏
  • 举报
回复
TO lufly2000(凌绝顶) :
如果用存储过程的话根本就不用把自动递增字段传入到存储过程中,也就是再存储过程的参数表里都不需要定义自动递增字段为传入参数(除非你要Insert操作后自动递增字段的返回值,即便如此自增字段也被定义为输出参数)。



qimini 2003-07-25
  • 打赏
  • 举报
回复
建议你用强类型的DataSet.问题就不会存在

或者是

DataColumn dc=new DataColumn("Test",Type.GetType(System.String));
dc.AutoIncrement;

table.Columns.Add(dc);

blueseasky 2003-07-25
  • 打赏
  • 举报
回复
直接写SQL语句当然会了,但对于更改DataGrid中的数据记录怎么做呢?怎么知道哪些是修改的,哪些是增加的记录又有哪些是删除的呢。用SqlCommandBuilder就方便的多。不用管状态,现在的问题是对于数据表中的主键字段是递增的,会有问题的,有谁遇到过这方面的问题?
remyxu 2003-07-25
  • 打赏
  • 举报
回复
UPDATE:

myConnection = new System.Data.SqlClient.SqlConnection
(System.Configuration.ConfigurationSettings.AppSettings["connectionstring"]);
myConnection.Open();

string renewstr = "UPDATE ptf_ptfinfo SET "
+ "cptf_testreq = '" + TextBox_testreq.Text+ "'"
+ " WHERE cptf_no = "
+ "'" + TextBox_ptfno.Text + "'";
SqlCommand renewcmd = new SqlCommand(renewstr,myConnection);
int rn = renewcmd.ExecuteNonQuery();
短短3句就OK!
remyxu 2003-07-25
  • 打赏
  • 举报
回复
非要用SqlCommandBuilder么?
我现在已经爱上了直接写SQL,INSERT、UPDATE、DELETE全用,快速简便,修改也方便!

给个例子:

string insertlogstr = "INSERT INTO ptf_log VALUES ( "
+ "'" + DateTime.Now + "',"
+ "'" + User.Identity.Name.ToUpper() + "',"
+ "'" + ClientIP + "',"
+ "'" + ClientNAME + "',"
+ "'UPDATEBASE',"
+ "'" + TextBox_ptfno.Text + "')";

SqlCommand insertlogcmd = new SqlCommand(insertlogstr,myConnection);
int insertrn = insertlogcmd.ExecuteNonQuery();

if ( insertrn <= 0 )
Response.Redirect("/WebApp_PTF/errorpage.htm");
blueseasky 2003-07-25
  • 打赏
  • 举报
回复
现在我还没插入数据库呢,怎么能知道@@IDENTITY呢?再说自动递增字段是不能手工指定值的,Insert和Update都不能操作自动递增字段!
lufly2000 2003-07-25
  • 打赏
  • 举报
回复
对于sql server数据库,可以用存储过程输出参数来返回数据库中自动增加的字段,对于access数据库,可以使用数据库自身的SELECT @@IDENTITY语句来返回库中自动增加的值,你可以在rowupdated事件中执行这个语句,下面的代码适用于access数据库

da.RowUpdated+=new OleDbRowUpdatedEventHandler(this.rowupdated);
...........
private void rowupdated(object sender,OleDbRowUpdatedEventArgs e)
{
if(e.StatementType==StatementType.Insert)
{
OleDbCommand comm=new OleDbCommand("SELECT @@IDENTITY",conn);
e.Row["主键字段"]=(int)comm.ExecuteScalar();
}
}

就是在rowupdated事件中将返回的值填入dataset中的主键字段中,msdn中有很详细的解释。。。。
zdsa 2003-07-25
  • 打赏
  • 举报
回复
不明白你的问题。

你可以将自增长字段帮定在datagrid上,但把该列设为不可见。江脱维删除和修改是的参数。

至于添加,你根本不用考虑。只将除了自增长字段的其他字段的值存入数据库,该条纪录的自增长字段自动生成,不用你手动设置。
blueseasky 2003-07-24
  • 打赏
  • 举报
回复
SqlCommandBuilder要求必须有主键字段,但在Insert操作时不能insert递增字段。所以两者有矛盾,如何解决?
xiaodele 2003-07-24
  • 打赏
  • 举报
回复
只要在DataGrid上没有冲突,用SqlCommandBuilder就不会有问题的
访问真八字排盘系统介绍: 1、八字排盘 八字排盘是将年月日时按照天干地支的形式进行排列,一个时间单位代表了一个柱。八字由年柱、月柱、日柱和时柱共四个柱组成,也被称为四柱八字。八字学中基于中国阴阳五行、天干地支与刑冲克害、以及民间盲派的神煞论等方式,进一步预测爱情顺遂、工作高低、姻缘好坏、财富高低、学业成就、身体健康等事的学问。 八字排盘由以下元素组合:年月日时四柱、大运干支、胎元 、流年干支、十神、地势、神煞等。生辰八字不只是把干支历计算出来,而还要遵守月令、节令的强弱,时辰的阴阳变化进行校正。排盘分析,就是根据出生者的性别、天干地支的阴阳五行关系、进一步推算出来的一套方法论,给预测者做人生吉凶的参考数据,在未来事业、财运、婚姻、家庭等问题时,能做出风险较低的决策。 八字排盘怎么看 八字排盘由年、月、日、时四柱组成,每柱包含一个天干和一个地支,共八个字。年柱代表出生的年份,月柱代表出生的月份,日柱代表出生的日期,时柱则代表出生的时辰。每个柱的干支组合都会对个人的命运产生影响。天干地支旁边标注的正财、偏财、偏印、正印、比肩、劫财、食神、伤官、正官、七杀等,称为十神。 2、八字排盘软件介绍 我们是腾讯云市场金牌合作伙伴,广州正规软件开发公司,开发的八字排盘系统数据最全面精准,我们八字排盘采用最精确的排盘程序,而且运用“真太阳时”,进行更精确的时间划分。大家都知道我们使用的北京时间,是统一规定的标准时间。而八字排盘需要相对于太阳方位的天文时间,即平太阳时。我们国家地大物博,北京时间19时,哈尔滨已经夜幕降临,而新疆却还是太阳高挂,这时哈尔滨的天文时间可能在20:00以后,而新疆的天文时间可能在16时以前。北京时间是东经120度经线的平太阳时,如果您出生地的经度与北京时间所处的经度差异较大,或者处于单数时间点的前后,比如6点差一刻,8点,10点15分等

111,097

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • AIGC Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧