vfp中使用insert向表中插入记录时遇到的问题
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vfp中使用insert向表中插入记录时遇到的问题相关的知识,希望对你有一定的参考价值。
用use <表名>打开表后,输入insert,出现了"在启用行缓冲或表缓冲,或使用完整性约束时,不能执行INSERT操作."的提示信息,请问这是为什么呢?
打开的表并没有设置参照完整性关联呀,只是建立了一个候选索引,刚刚把那个候选索引改为普通索引后再在命令窗口中输入insert后就能打开表的编辑窗口插入新记录了.这是否说明insert命令也不能在建立了普通索引或主索引的表中使用呢?vfp的insert命令和SQL的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时,不能向表中插入显式值