vfp中使用insert向表中插入记录时遇到的问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vfp中使用insert向表中插入记录时遇到的问题相关的知识,希望对你有一定的参考价值。

用use <表名>打开表后,输入insert,出现了"在启用行缓冲或表缓冲,或使用完整性约束时,不能执行INSERT操作."的提示信息,请问这是为什么呢?
打开的表并没有设置参照完整性关联呀,只是建立了一个候选索引,刚刚把那个候选索引改为普通索引后再在命令窗口中输入insert后就能打开表的编辑窗口插入新记录了.这是否说明insert命令也不能在建立了普通索引或主索引的表中使用呢?vfp的insert命令和SQL的insert命令有哪些不同呀?

参考技术A 这是由于设置了参照完整性关联,可能设置了插入限制,VF的insert命令的缺点,但是用SQL的insert 命令就没问题了。 参考技术B 在启用行缓冲或表缓冲,或使用完整性约束时,不能执行INSERT操作,因为缓冲的作用就是,改变的东西在内存里放着,并不是立即更新的,所以insert与update操作不会有用的,只有取消表的缓冲。 参考技术C 因为使用INSERT命令时,如果设置了主索引,那么主索引的字段值是不能为空的。所以出现你说的问题。本回答被提问者采纳 参考技术D 在启用缓冲或表缓冲,或者使用完整性约束时,不能执行insert操作。用
cursorsetprop()
函数设置
buffering
属性为
1
,将行缓冲或表缓冲关闭。或者使用
append
代替
insert

IDENTITY_INSERT设置为OFF时,不能向表中插入显式值

项目场景:

数据库:SQL Server

数据表carsAll中ID是自增字段


问题描述:

insert的数据字段中包含自增的ID,在向数据库插入数据过程中出现了 IDENTITY_INSERT设置为OFF时,不能向表中插入显式值的问题


原因分析:

错误提示信息还是很友好,很明了的,已经告诉我们不能显式插入值了,就是说要插入值的字段中包含了数据库设计时默认自增的字段,默认自增就是让数据库表自己悄悄计数啊,所以默认自增的字段就是导致报错的原因了


解决方案:

原因找到了,再说说解决办法吧!

SET IDENTITY_INSERT 提示报错的表名  ON 

INSERT INTO 报错的表名 (id,...) VALUES (1,...)

SET IDENTITY_INSERT  提示报错的表名  OFF

上面的SQL语句就是让这个表可以显式插入值,然后把数据添加进去,当然这样插入数据应该都是不得已,以后还是要遵守表ID自增的原则的,所以最后不要忘了恢复OFF状态哦!

以上是关于vfp中使用insert向表中插入记录时遇到的问题的主要内容,如果未能解决你的问题,请参考以下文章

SQL INSERT INTO 语句:向表中插入新记录语法及案例剖析

IDENTITY_INSERT设置为OFF时,不能向表中插入显式值

IDENTITY_INSERT设置为OFF时,不能向表中插入显式值

IDENTITY_INSERT设置为OFF时,不能向表中插入显式值

IDENTITY_INSERT设置为OFF时,不能向表中插入显式值

如何用SQL语句向一个表中插入多行记录