sql DEFAULT 和 NULL 不允许作为显式标识值
来源:互联网 发布:刷留言软件 编辑:程序博客网 时间:2024/04/20 13:13
SQL INSERT INTO错误: DEFAULT 和 NULL 不允许作为显式标识值
错误原因:插入值时自增列插入了值,我的表主键设置为自增列,当插入数据时不允许将数值插入自增列。
如下:
insert into table(id,name,address) ---错误:id为自增列
values(1,'lipang','shandong')
改为:
insert into table(name,address) ---正确
values('lipang','shandong')
select @@identify as id ----返回当前插入数据的标识(或主键)
msdn中文档摘要:
在一条 INSERT、SELECT INTO 或大容量复制语句完成后,@@IDENTITY 中包含语句生成的最后一个标识值。 如果语句未影响任何包含标识列的表,则 @@IDENTITY 返回 NULL。 如果插入了多个行,生成了多个标识值,则 @@IDENTITY 将返回最后生成的标识值。 如果语句触发了一个或多个触发器,该触发器又执行了生成标识值的插入操作,那么,在语句执行后立即调用 @@IDENTITY 将返回触发器生成的最后一个标识值。 如果对包含标识列的表执行插入操作后触发了触发器,并且触发器对另一个没有标识列的表执行了插入操作,则 @@IDENTITY 将返回第一次插入的标识值。 出现 INSERT 或 SELECT INTO 语句失败或大容量复制失败,或者事务被回滚的情况时,@@IDENTITY 值不会恢复为以前的设置。
如果语句和事务失败,它们会更改表的当前标识,从而使标识列中的值出现不连贯现象。 即使未提交试图向表中插入值的事务,也永远无法回滚标识值。 例如,如果因 IGNORE_DUP_KEY 冲突而导致 INSERT 语句失败,表的当前标识值仍然会增加。
@@IDENTITY、SCOPE_IDENTITY 和 IDENT_CURRENT 是相似的函数,因为他们都返回插入到表的 IDENTITY 列的最后一个值。
@@IDENTITY 和 SCOPE_IDENTITY 可以返回当前会话中的所有表中生成的最后一个标识值。 但是,SCOPE_IDENTITY 只在当前作用域内返回值,而 @@IDENTITY 不限于特定的作用域。
IDENT_CURRENT 不受作用域和会话的限制,而受限于指定的表。 IDENT_CURRENT 可以返回任何会话和任何作用域中为特定表生成的标识值。 有关详细信息,请参阅IDENT_CURRENT (Transact-SQL)。
@@IDENTITY 函数的作用域是执行该函数的本地服务器上的当前会话。 此函数不能应用于远程或链接服务器。 若要获得其他服务器上的标识值,请在远程服务器或链接服务器上执行存储过程,并使(在远程或链接服务器的环境中执行的)该存储过程收集标识值,并将其返回本地服务器上的发出调用的连接。
复制可能会影响 @@IDENTITY 值,因为该值在复制触发器及存储过程中使用。 如果此列是复制项目的一部分,则 @@IDENTITY 不是最近用户创建的标识的可靠指示器。 您可以使用 SCOPE_IDENTITY() 函数语法代替 @@IDENTITY。
- sql DEFAULT 和 NULL 不允许作为显式标识值
- SQL建表字段语法DEFAULT和字段 NULL的组合定义表现
- Sql Server数据表中使用 GUID 值来作为行标识
- 使用Guid值作为数据库行标识
- 使用Guid值作为数据库行标识
- SQL 数据库 学习 010 表和约束的区别、check约束、default约束、unique约束、not null约束
- sql server 空值,null,和0
- SQL标识值 (转)
- T-SQL获取标识值
- SQL is NULL 和 = NULL区别
- SQL得到标识列的下一个标识值
- SQL得到标识列的下一个标识值
- (转帖)使用 GUID 值来作为数据库行标识
- 使用 GUID 值来作为数据库行标识
- 使用 GUID 值来作为数据库行标识(转载)
- 使用 GUID 值来作为数据库行标识
- 使用 GUID 值来作为数据库行标识
- 使用 GUID 值来作为数据库行标识
- android usb mass storage EMMC转化为SD卡(二)
- XsqlFilterResult----动态生成sql语句的类,过滤一些为空的查询条件 .
- js 字符串函数
- 判断是否为平板
- Qtopia4.4.3移植到AtmelAT91SAM9X5-EK开发板
- sql DEFAULT 和 NULL 不允许作为显式标识值
- 读取客户端文件
- xcode workspace 及静态库创建
- 使用lsusb命令查看系统中的USB设备
- json对象和数组对象
- C# String.Format格式说明
- C语言学生管理系统
- GCD ios多线程 runloop
- MySQL复制--最快的从库搭建方法(tar包)