社区
C#
帖子详情
对于主键是自动递增字段的表用SqlCommandBuilder如何增删改数据表?
blueseasky
2003-07-24 05:31:02
在WinFrom下的DataGrid中进行数据的增删改操作,最后想用SqlCommandBuilder更新数据库,怎么写?
...全文
153
14
打赏
收藏
对于主键是自动递增字段的表用SqlCommandBuilder如何增删改数据表?
在WinFrom下的DataGrid中进行数据的增删改操作,最后想用SqlCommandBuilder更新数据库,怎么写?
复制链接
扫一扫
分享
举报
写回复
配置赞助广告
14 条
回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
打赏红包
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就不会有问题的
相关推荐
8.1.6 创建
数据表
时指定
主键
默认
递增
8.1.6 创建
数据表
时指定
主键
默认
递增
MySQL支持将整数类型的
主键
设置为默认
递增
类型,这样在向
数据表
插入数据时,可以不用指定整数类型
主键
的值,MySQL会将该表的整数类型的
主键
值
自动
加1。 1.语法格式 MySQL中设置整数类型的
主键
值默认
递增
的语法格式如下:
字段
名称 数据类型 AUTO_INCREMENT 可以看出,只需要在整数类型的
主键
字段
后面加上A...
数据表
的基本操作
数据表
的
增删
书
改
查 1 #
数据表
的
增删
改
查 2 3 # 并设置
数据表
的存储引擎alter 4 create database test_review; 5 use test_review; 6 7 # 创建
数据表
设置
主键
约束性
字段
8 9 # 但
字段
主键
只有一个
主键
primary key 10 create table review( 11 i...
在mysql中删除张三的信息_mysql 表基本
增删
查
改
对表的操作是在某个数据库下才能进行的,所以要先选择数据库 "use 数据库名;"1、创建
数据表
1)"create table 表名 (
字段
1 类型 [约束],
字段
2 类型 [约束]);"创建
数据表
创建学生信息表,包含
字段
(id,姓名,性别,生日),其中id为
主键
mysql>create table stu(-> stu_id intauto_increment prim...
mysql基本
增删
查
改
_mysql 表基本
增删
查
改
对表的操作是在某个数据库下才能进行的,所以要先选择数据库 "use 数据库名;"1、创建
数据表
1)"create table 表名 (
字段
1 类型 [约束],
字段
2 类型 [约束]);"创建
数据表
创建学生信息表,包含
字段
(id,姓名,性别,生日),其中id为
主键
mysql>create table stu(-> stu_id intauto_increment prim...
mysql数据库的4种基本操作是_mysql数据库基本操作(三)
数据表
操作基础操作1.创建表(类似于一个excel表)create tabletab_name(field1 type[完整性约束条件],field2 type,...fieldn type)[character set xxx];数据库的
增删
查
改
和数据类型掌握后,就可以开始在数据库里面建表了,首先有一个
主键
的概念:能够唯一区分出当前记录的
字段
称为
主键
,
主键
要是非空且唯一的,且
字段
一定要是数字类型...
发帖
C#
C#
.NET技术 C#
复制链接
扫一扫
10.8w+
社区成员
64.2w+
社区内容
.NET技术 C#
社区管理员
加入社区
获取链接或二维码
帖子事件
创建了帖子
2003-07-24 05:31
社区公告
让您成为最强悍的C#开发者