create table (  ide int identity(1,1))

解决方案 »

  1.   

    也可以:
    select identity(int,1,1) as id,其他字段
    into 新生成的表
    from old_table
      

  2.   

    IDENTITY(属性)
    在表中创建一个标识列。该属性与 CREATE TABLE 及 ALTER TABLE Transact-SQL 语句一起使用。说明  IDENTITY 属性与 SQL-DMO Identity 属性不同,后者表现列的行标识属性。 
    语法
    IDENTITY [ ( seed , increment ) ]参数
    seed装载到表中的第一个行所使用的值。increment增量值,该值被添加到前一个已装载的行的标识值上。必须同时指定种子和增量,或者二者都不指定。如果二者都未指定,则取默认值 (1,1)。
      

  3.   

    IDENTITY(函数)
    只用在带有 INTO table 子句的 SELECT 语句中,以将标识列插入到新表中。尽管类似,但是 IDENTITY 函数不是与 CREATE TABLE 和 ALTER TABLE 一起使用的 IDENTITY 属性。语法
    IDENTITY ( data_type [ , seed , increment ] ) AS column_name
      

  4.   

    到帮助里查看一下  identity 的用法
      

  5.   

    --如果是自己要控制生成字段的值的规则,比如每日的编号不同,可以用类似下面的方法:--自已做标识列的例子--流水号:日期+当日编号:--创建得到最大id的函数
    create function f_getid()
    returns varchar(12)
    as
    begin
    declare @id varchar(12),@dt varchar(8)
    select @dt=dt from v_getdate
    select @id=max(id) from tb where id like @dt+'-%'
    if @id is null
    set @id=@dt+'-'+'001'
    else
    set @id=@dt+'-'+right('000'+cast(cast(right(@id,3) as int)+1 as varchar),3)
    return(@id)
    end
    go--创建表
    create table tb(id varchar(20) default dbo.f_getid() primary key,name varchar(10))
    go--创建视图,得到当前日期(因为函数中不能使用getdate())
    create view v_getdate as select dt=convert(varchar,getdate(),112)
    go--插入记录测试
    insert into tb(name) values('张三')
    insert into tb(name) values('张四')
    insert into tb(name) values('张五')
    insert into tb(name) values('张六')
    insert into tb(name) values('张七')
    insert into tb(name) values('张八')
    insert into tb(name) values('张九')
    insert into tb(name) values('张十')--显示插入的结果
    select * from tbgo
    --删除环境
    drop table tb
    drop view v_getdate
    drop function f_getid