在sqlserver中对某张表主键使用identity(自动增长)时,在对该张表再进行插入数据,数据插不了,且出现如

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在sqlserver中对某张表主键使用identity(自动增长)时,在对该张表再进行插入数据,数据插不了,且出现如相关的知识,希望对你有一定的参考价值。

“仅当使用了列列表并且 IDENTITY_INSERT 为 ON 时,才能为表'T_admin'中的标识列指定显式值。”这是什么意思呀

参考技术A 你在写Insert语句时,字段列表包含了具有IDENTITY属性的列,如ID之类的,把这个列从你的插入字段列表中去掉就行了。 参考技术B 不能对这个列插入值,你在插入的过程中此列不插值就行了。
如:t_admin(d1(自增值),d2,d3)
要用:insert into t_admin(d2,d3) values(v2,v3)
或insert into t_admin(d2,d3) select v2,v3 from 其他表
不能用:insert into t_admin select v1,v2,v3 from 其他表
参考技术C 在插入数据时,不要对主键赋值:
例如 表 A 中 有字段 F1,F2,F3 其中F1为自动增长,那么在SQL 应该为
Insert into A (F2,F3 ) values ('','')
F1会自动赋值
参考技术D identity字段是不需要插入数据的,会自动自增

oracle怎么查看外键在哪个表

有时候删除某张表记录的时候,会报错外键约束不能删除。

如果不了解表之间的关系,可以通过以下语句查询到外键是建在哪张表上的:

select * from dba_constraints where constraint_name=\'xxx\' and constraint_type = \'R\';

例如:我的程序日志中报如下错误,我要知道外键是在那个表上.
2015-09-08
18:28:18 [ main:261597003 ] - [ ERROR ] java.sql.SQLException:
ORA-02291: 违反完整约束条件 (IRP.FK66EC57AF5158B9FB) - 未找到父项关键字

select * from dba_constraints where constraint_name=\'FK66EC57AF5158B9FB\' and constraint_type = \'R\';

例如:

执行delete from tablename时报错:

ORA-02292: integrity constraint (CCSYS.FK_T_BME_TASKRUNRESULT_TASKID) violated - child record found

可以通过执行

select table_name from dba_constraints where constraint_name=\'FK_T_BME_TASKRUNRESULT_TASKID\' and constraint_type = \'R\';

查询出外键是建在T_BME_TASKRUNRESULT表上的,先把T_BME_TASKRUNRESULT表删除,就可以删除 t_bme_task表记录了。
参考技术A 如果不了解表之间的关系,可以通过以下语句查询到外键是建在哪张表上的:
select * from dba_constraints where constraint_name='xxx' and constraint_type = 'R';
例如:我的程序日志中报如下错误,我要知道外键是在那个表上.
2015-09-0818:28:18 [ main:261597003 ] - [ ERROR ] java.sql.SQLException:
ORA-02291: 违反完整约束条件 (IRP.FK66EC57AF5158B9FB) - 未找到父项关键字
select * from dba_constraints where constraint_name='FK66EC57AF5158B9FB' and constraint_type = 'R';本回答被提问者采纳

以上是关于在sqlserver中对某张表主键使用identity(自动增长)时,在对该张表再进行插入数据,数据插不了,且出现如的主要内容,如果未能解决你的问题,请参考以下文章

sqlserver 关联查询 charindex 函数 查询慢,不使用索引问题解决办法

查看SqlServer某张表的物理空间占用情况

SQL查找两张表主键相同的数据

sql 设置主键 自动增长

mysql如何查看当前分区表的情况?

sqlserver 修改某张表某字段 排序规则;sqlserver 少量中文 问号?;sqlserver 生僻字;sqlserver 少量中文乱码;sqlserver COLLATE用法;sqlser