广告位联系
返回顶部
分享到

sql IDENTITY_INSERT对标识列的作用和使用

MsSql 来源:互联网 作者:佚名 发布时间:2023-01-04 21:37:11 人浏览
摘要

一般情况下,当数据表中,莫一列被设置成了标识列之后,是无法向标识列中手动的去插入标识列的显示值。但是,可以通过设置SET IDENTITY_INSERT属性来实现对标识列中显示值的手动插入

一般情况下,当数据表中,莫一列被设置成了标识列之后,是无法向标识列中手动的去插入标识列的显示值。但是,可以通过设置SET IDENTITY_INSERT属性来实现对标识列中显示值的手动插入。

写法:

1).SET IDENTITY_INSERT 表名 ON :表示开启对标识列显示值插入模式,允许对标识列显示值进行手动插入数据。

2).SET IDENTITY_INSERT 表名 OFF:表示关闭对标识列显示值的插入操作,标识列不允许手动插入显示值。

注意:IDENTITY_INSERT的开启ON和关闭OFF是成对出现的,所以,在执行完手动插入操作之后,记得一定要把IDENTITY_INSERT设置为OFF,否则下次的自动插入数据会插入失败。

例如:

创建一张表b1,b_id为标识列,设置为唯一标识,从1开始,每次插入新数据时,值都递增1,不允许为空:

1

2

3

4

5

CREATE table b1

(

  b_id int identity(1,1) primary key not null,  

  b_name varchar(20) null

)

当把表b1中b_id这一列设置为唯一标识列的时候,IDENTITY_INSERT属性的值就默认被设置为了OFF了。标识列b_id列不允许手动去插入显示值,只能由系统自动按照排顺序去插入显示的值。

1.当IDENTITY_INSERT 为OFF时,往表b1中插入2条数据,往标识列中手动插入显示值:

 代码1:

1

2

insert into b1(b_id,b_name) values(1,'莉莉')

insert into b1(b_id,b_name) values(2,'阿呆')

插入结果:

代码2:

1

2

insert into b1(b_name) values('莉莉')

insert into b1(b_name) values('阿呆')

插入结果:

说明:当把IDENTITY_INSERT设置为OFF时,标识列是不允许手动插入显示值的,只能有系统去自动插入标识列的显示值。

2.当IDENTITY_INSERT 为ON时,往表b1中插入2条数据,往标识列中手动插入显示值:

代码1:

set identity_insert b1 on --开启对标识列的插入模式,标识列允许手动插入显示值

1

2

insert into b1(b_id,b_name) values(8,'小白')  --手动去插入标识列b_id的显示值为8

insert into b1(b_id,b_name) values(9,'小黑')

set identity_insert b1 off --关闭对标识列的插入操作,标识列不允许手动插入显示值

插入结果:

代码2:

set identity_insert b1 on --开启对标识列的插入模式,标识列允许手动插入显示值

1

2

insert into b1(b_name) values('小胖')  --手动去插入标识列b_id的显示值为8

insert into b1(b_name) values('小宝')

set identity_insert b1 off --关闭对标识列的插入操作,标识列不允许手动插入显示值

插入结果:

说明:当设置IDENTITY_INSERT为ON时,必须要指定标识列中要插入的的显示值,要手动的插入标识列中的显示值。因为系统将不再对标识列的显示值自动插入了。所以,必须要手动去给标识列插入显示值。


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://blog.csdn.net/qq112212qq/article/details/84634774
相关文章
  • 嵌入式SQL的详细介绍

    嵌入式SQL的详细介绍
    嵌入式SQL概述 嵌入式SQL(Embedded SQL) 是应用系统使用编程方式来访问和管理数据库中数据的主要方式之一。 SQL语言有两种使用方式:一种是作
  • sql IDENTITY_INSERT对标识列的作用和使用
    一般情况下,当数据表中,莫一列被设置成了标识列之后,是无法向标识列中手动的去插入标识列的显示值。但是,可以通过设置SET IDENTI
  • SQL多表联合查询时如何采用字段模糊匹配

    SQL多表联合查询时如何采用字段模糊匹配
    背景:由于业务或是其他不描述的原因的问题导致原有存储的数据发生变动,与现有数据有差别,但还是能勉强看明白数据内容。 要求:实
  • 清除SQL Server数据库日志(ldf文件)的方法

    清除SQL Server数据库日志(ldf文件)的方法
    清除SQL Server数据库日志(ldf文件)的几种方法 随着系统运行时间的推移,数据库日志文件会变得越来越大,这时我们需要对日志文件进行备份
  • if exists的用法及说明
    1 判断数据库是否存在 1 2 if exists (select * from sys.databases where name = 数据库名) drop database [数据库名] 2 判断表是否存在 1 2 if exists (select * from
  • SQL Server ISNULL 不生效原因及解决方法
    SQL Server ISNULL 不生效原因 数据库:SQL Server 2008 R2 原始SQL:historyval 字段没有数据显示为NULL,用ISNULL判断为NULL的时候替换为 0.0 1 2 3 4 5 6 SE
  • 恢复SQLSERVER的master系统库的方法

    恢复SQLSERVER的master系统库的方法
    一、问题描述 SQL Server 的master数据库不能像其他用户或 系统数据库一样恢复, 因为没有活动的master数据库 SQL Server 无法执行。虽然很少需要
  • SQL Server还原完整备份和差异备份的操作过程

    SQL Server还原完整备份和差异备份的操作过程
    1.首先右键数据库,点击还原数据库: 然后会打开还原数据库窗口,如图所示: 首先 源 选择设备,并且选择到完整备份的数据库备份文件
  • SQL Server查询结果导出到EXCEL表格的图文教程

    SQL Server查询结果导出到EXCEL表格的图文教程
    需求: 将查询的两列数据导出到excel中 1.选择数据库,右键任务导出数据,打开导入导出向导,单击下一步 2.在打开的SQL Server导入和导出的
  • SQL Server实现group_concat功能的实例

    SQL Server实现group_concat功能的实例
    一、实现 #tmp表内容如下: 实现group_concat的sql语句为: 1 2 3 4 5 6 7 8 9 10 11 12 Select RegionID, STUFF( ( SELECT , + T.c1 FROM #tmp T WHERE A.regionid = T.regi
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计