一、标识列的定义以及特点
  SQL
Server中的标识列又称标识符列,习惯上又叫自增列。
  该种列具有以下三种特点:
  1、列的数据类型为不带小数的数值类型
  2、在进行插入(Insert)操作时,该列的值是由系统按一定规律生成,不允许空值
  3、列值不重复,具有标识表中每一行的作用,每个表只能有一个标识列。
  由于以上特点,使得标识列在数据库的设计中得到广泛的使用。
  二、标识列的组成
  创建一个标识列,通常要指定三个内容:
  1、类型(type)
  在SQL
Server 2000中,标识列类型必须是数值类型,如下:
  decimal、int、numeric、smallint、bigint
、tinyint
  其中要注意的是,当选择decimal和numeric时,小数位数必须为零
  另外还要注意每种数据类型所有表示的数值范围
  2、种子(seed)
  是指派给表中第一行的值,默认为1
  3、递增量(increment)
  相邻两个标识值之间的增量,默认为1。
  三、标识列的创建与修改
  标识列的创建与修改,通常在企业管理器和用Transact-SQL语句都可实现,使用企业管理管理器比较简单,请参考SQL
Server的联机帮助,这里只讨论使用Transact-SQL的方法
  1、创建表时指定标识列
  标识列可用 IDENTITY
属性建立,因此在SQL
Server中,又称标识列为具有IDENTITY属性的列或IDENTITY列。
  下面的例子创建一个包含名为ID,类型为int,种子为1,递增量为1的标识列
  CREATE
TABLE T_test
  (ID int IDENTITY(1,1),
  Name
varchar(50)
  )
  2、在现有表中添加标识列
  下面的例子向表T_test中添加一个名为ID,类型为int,种子为1,递增量为1的标识列
  --创建表
  CREATE
TABLE T_test
  (Name varchar(50)
  )
  --插入数据
  INSERT T_test(Name)
VALUES(’张三’)
  --增加标识列
  ALTER TABLE T_test
  ADD ID int
IDENTITY(1,1)
  3、判段一个表是否具有标识列
  可以使用 OBJECTPROPERTY 函数确定一个表是否具有
IDENTITY(标识)列,用法:
  Select
OBJECTPROPERTY(OBJECT_ID(’表名’),’TableHasIdentity’)
  如果有,则返回1,否则返回0
  4、判断某列是否是标识列
  可使用
COLUMNPROPERTY 函数确定 某列是否具有IDENTITY 属性,用法
  SELECT COLUMNPROPERTY(
OBJECT_ID(’表名’),’列名’,’IsIdentity’)
  如果该列为标识列,则返回1,否则返回0
  5、查询某表标识列的列名
  SQL
Server中没有现成的函数实现此功能,实现的SQL语句如下
  SELECT COLUMN_NAME FROM
INFORMATION_SCHEMA.columns
  WHERE TABLE_NAME=’表名’ AND
COLUMNPROPERTY(
  OBJECT_ID(’表名’),COLUMN_NAME,’IsIdentity’)=1
  6、标识列的引用
  如果在SQL语句中引用标识列,可用关键字IDENTITYCOL代替
  例如,若要查询上例中ID等于1的行,
  以下两条查询语句是等价的
  SELECT
* FROM T_test WHERE IDENTITYCOL=1
  SELECT * FROM T_test WHERE
ID=1
  7、获取标识列的种子值
  可使用函数IDENT_SEED,用法:
  SELECT IDENT_SEED
(’表名’)
  8、获取标识列的递增量
  可使用函数IDENT_INCR ,用法:
  SELECT
IDENT_INCR(’表名’)
  9、获取指定表中最后生成的标识值
  可使用函数IDENT_CURRENT,用法:
  SELECT
IDENT_CURRENT(’表名’)
  注意事项:当包含标识列的表刚刚创建,为经过任何插入操作时,使用IDENT_CURRENT函数得到的值为标识列的种子值,这一点在开发数据库应用程序的时候尤其应该注意。
  总结一下标识列在复制中的处理方法
  1、快照复制
  在快照复制中,通常无须考虑标识列的属性。
  2、事务复制
  举例:
  发布数据库A,订阅数据库B,出版物为T_test_A,订阅表为T_test_B
  CREATE
TABLE T_test_A
  (ID int IDENTITY(1,1),
  Name
varchar(50)
  )
  CREATE TABLE T_test_B
  (ID int
IDENTITY(1,1),
  Name
varchar(50)
  )
  在这种情况下,复制代理将无法将新行复制到库B,因为列ID是标识列,不能给标识列显示提供值,复制失败。
  这时,需要为标识列设置NOT
FOR REPLICATION 选项。这样,当复制代理程序用任何登录连接到库B上的表T_test时,该表上的所有 NOT
  FOR
REPLICATION
选项将被激活,就可以显式插入ID列。
  这里分两种情况:
  1、库B的T_test表不会被用户(或应用程序)更新
  最简单的情况是:如果库B的T_test不会被用户(或应用程序)更新,那建议去掉ID列的标识属性,只采用简单int类型即可。
  2、库B的T_test表是会被其他用户(或应用程序)更新
  这种情况下,两个T_test表的ID列就会发生冲突,举例:
  在库A中执行如下语句:
  INSERT
T_test_A(Name) VALUES(’Tom’)(假设ID列为1)
  在库B中执行如下语句:
  INSERT
T_test_B(Name)
VALUES(’Pip’)(假设ID列为1)
  这样,就会在库A和库B的两个表分别插入一条记录,显然,是两条不同的记录。
  然而事情还没有结束,待到预先设定的复制时间,复制代理试图把记录"1
TOM"插入到库B中的T_test表,但库B的T_test_B表已经存在
  ID为1的列,插入不会成功,通过复制监视器,我们会发现复制失败了。
  解决以上问题的方法有:
  (1)为发布方和订阅方的标识列指定不同范围的值,如上例可修改为:
  --确保该表记录不会超过10000000
  CREATE
TABLE T_test_A
  (ID int IDENTITY(1,1),
  Name
varchar(50)
  )
  CREATE TABLE T_test_B
  (ID int
IDENTITY(10000000,1),
  Name varchar(50)
  )
  (2)使发布方和订阅方的标识列的值不会重复,

  --使用奇数值
  CREATE TABLE T_test_A
  (ID int IDENTITY(1,2),
  Name
varchar(50)
  )
  --使用偶数值
  CREATE TABLE T_test_B
  (ID int
IDENTITY(2,2),
  Name
varchar(50)
  )
  这种办法可推广,当订阅方和发布方有四处时,标识列属性的定义分别如下
  (1,4),(2,4),(3,4),(4,4)
  3、合并复制
  采用事务复制中解决方法,只要使发布表和订阅表标识列的值不重复既可。

关于SQL Server数据库中的标识列的更多相关文章

  1. 浅析SQL Server数据库中的伪列以及伪列的含义

    SQL Server中的伪列 下午看QQ群有人在讨论(非聚集)索引的存储,说,对于聚集索引表,非聚集索引存储的是索引键值+聚集索引键值:对于非聚集索引表,索引存储的是索引键值+RowId,这应该是一个 ...

  2. 转:SQL SERVER数据库中实现快速的数据提取和数据分页

    探讨如何在有着1000万条数据的MS SQL SERVER数据库中实现快速的数据提取和数据分页.以下代码说明了我们实例中数据库的“红头文件”一表的部分数据结构: CREATE TABLE [dbo]. ...

  3. .NET客户端下载SQL Server数据库中文件流保存的大电子文件方法(不会报内存溢出异常)

    .NET客户端下载SQL Server数据库中文件流保存的大电子文件方法(不会报内存溢出异常) 前段时间项目使用一次性读去SQL Server中保存的电子文件的文件流然后返回给客户端保存下载电子文件, ...

  4. sql server数据库中char,varchar,nvarchar字段的区别

    Char,varchar,nvarchar字段是sql server数据库中的三种字段类型.好多人在选择存储的时候不知道如何抉择,我给大家讲下这个三个字段类型的区别. Char(n)是长度为n个字节的 ...

  5. 清空SQL Server数据库中所有表数据的方法(转)

    清空SQL Server数据库中所有表数据的方法 其实删除数据库中数据的方法并不复杂,为什么我还要多此一举呢,一是我这里介绍的是删除数据库的所有数据,因为数据之间可能形成相互约束关系,删除操作可能陷入 ...

  6. SQL server数据库中的DateTime类型出现的问题

    我们知道这个SQL server数据库中的DateTime类型是数据库应用开发中经经常使用到的一种数据类型.而C#语言中也有DateTime类型,尽管二者都是用来描写叙述时间的,可是它们的默认值是不同 ...

  7. C#同步SQL Server数据库中的数据--数据库同步工具[同步新数据]

    C#同步SQL Server数据库中的数据 1. 先写个sql处理类: using System; using System.Collections.Generic; using System.Dat ...

  8. C#从SQL server数据库中读取l图片和存入图片

    原文:C#从SQL server数据库中读取l图片和存入图片 本实例主要介绍如何将图片存入数据库.将图片存入数据库,首先要在数据库中建立一张表,将存储图片的字段类型设为Image类型,用FileStr ...

  9. 清空SQL Server数据库中所有表数据的方法

    原文:清空SQL Server数据库中所有表数据的方法 其实删除数据库中数据的方法并不复杂,为什么我还要多此一举呢,一是我这里介绍的是删除数据库的所有数据,因为数据之间可能形成相互约束关系,删除操作可 ...

随机推荐

  1. [hdu4734]F(x)数位dp

    题意:求0~f(b)中,有几个小于等于 f(a)的. 解题关键:数位dp #include<bits/stdc++.h> using namespace std; typedef long ...

  2. Java 常见注解

    @Retention 1.RetentionPolicy.SOURCE —— 这种类型的Annotations只在源代码级别保留,编译时就会被忽略2.RetentionPolicy.CLASS —— ...

  3. 项目中缺少org.wltea.ik-analyzer如何解决?

    IKAnalyzer是一个开源的,基于java语言开发的轻量级的中文分词工具包.从2006年12月推出1.0版开始,IKAnalyzer已经推出了3个大版本.最初,它是以开源项目Luence为应用主体 ...

  4. From COM to COM 侯捷 1998.06.12

    摘要: 本文簡介 C++ Object Model 和 Component Object Model 的基本概念,並引介四本書籍: 1. Inside The C++ Object Model 2. ...

  5. 机房重构——泛型和“DataTable”

    前言 我们都知道在机房重构的时候,大多数都在用七层进行重构,每一层都依赖实体.所以不管怎么调用,返回的应该是实体参数,这样才符合大多数的逻辑,这样我们试想一下,如果我们要求在U层返回多个实体值,怎么办 ...

  6. hdu 2147 kiki's game(巴什博弈)

    kiki's game HDU - 2147 题意:一个n*m的表格,起始位置为右上角,目标位置为左下角,甲先开始走,走的规则是可以向左,向下或者向左下(对顶的)走一格.谁先走到目标位置谁就胜利.在甲 ...

  7. Cogs 6. 线型网络

    6. 线型网络 ★★☆   输入文件:linec.in   输出文件:linec.out   简单对比时间限制:1 s   内存限制:256 MB [问题描述] 有 N(N<=20)台 PC 放 ...

  8. 洛谷P4287 [SHOI2011]双倍回文(回文自动机)

    传送门 听说有大佬用manacher$O(n)$过此题……太强啦…… 说一下PAM的做法吧.(看了题解之后发现)蛮简单的 我们肯定要先建出回文自动机的 然后如果是枚举每一个节点暴跳fail指针肯定得T ...

  9. tomcat与jetty接收请求参数的区别

    [场景] 服务端点对点通知.A服务发起请求B服务,B同步返回接收成功:然后B开始处理逻辑:B处理完成后异步通知给A:A接收请求并处理,同步回写响应给B:完成. [先上代码] 服务端(接收端)代码: i ...

  10. 带权并查集【bzoj3362】: [Usaco2004 Feb]Navigation Nightmare 导航噩梦

    [bzoj]3362: [Usaco2004 Feb]Navigation Nightmare 导航噩梦 ​ 农夫约翰有N(2≤N≤40000)个农场,标号1到N,M(2≤M≤40000)条的不同的垂 ...