MsSql判断表是否有自增标识

Posted ymworkroom

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MsSql判断表是否有自增标识相关的知识,希望对你有一定的参考价值。

如果表有自增标识,那么就不能给这个自增列插入值或者更新这个列。

当然,如果要强制插入标识列也是可以的,只要设置Identity_insert为on即可,语法:

set Identity_insert tablename on;
insert into tablename (col1,col2) values (value1,value2)

但有时候我们在操作表的时候,我们并不知道这个表有没有标识列,如果有自增的标识列,我们可以用上面的方法打开开关进行插入,但是如果这个表是没有自增列的,用了上面的方法就会报错,所以我们有必要在使用这个开关语句的时候先判断一下这个表是不是有标识列,判断的SQL语句有两种:

select * from syscolumns where id=object_id(Ntablename) and COLUMNPROPERTY(id,name,IsIdentity)=1;


select * from syscolumns where id=object_id(Ntablename) and status=0x80

两种方法都可以

以上是关于MsSql判断表是否有自增标识的主要内容,如果未能解决你的问题,请参考以下文章

sql server建表时怎么设置ID字段自增

sql server 2000 中怎么去掉 和 还原 自增字段

php学习笔记-while循环

db2db 数据库转换设置自增的必须为主键 但是否怎么办

如何在mssql中获取最新自增ID的值

SQL更改表字段为自增标识