顺便问问联合主键 是多个主键还是一个主键剩下的是索引马

解决方案 »

  1.   

    楼上都说了
    比如学生选课表里StudentCourse(StuID,CourseID,Score)
    应该是StuID,CourseID为联合主键
      

  2.   

    如何取主键字段名称及字段类型--得到主键字段名1:
    SELECT TABLE_NAME,COLUMN_NAME FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE 
    WHERE TABLE_NAME<>'dtproperties'2:
    EXEC sp_pkeys @table_name='表名'3:
    select o.name as 表名,c.name as 字段名,k.colid as 字段序号,k.keyno as 索引顺序,t.name as 类型
    from sysindexes i
    join sysindexkeys k on i.id = k.id and i.indid = k.indid
    join sysobjects o on i.id = o.id
    join syscolumns c on i.id=c.id and k.colid = c.colid
    join systypes t on c.xusertype=t.xusertype
    where o.xtype = 'U' and o.name='要查询的表名'
    and exists(select 1 from sysobjects where xtype = 'PK' and parent_obj=i.id and name = i.name)
    order by o.name,k.colid
      

  3.   

    SQL SERVER获得指定表的主键

    http://www.cnblogs.com/piaoqingsong/archive/2007/05/18/751533.html
      

  4.   

    2     Declare @table_name varchar(100)
     3     Set @table_name='table_Pqs'
     4     --1、可以根据系统存储过程
     5     Execute   sp_pkeys @table_name
     6 
     7     --2、根据系统表获得
     8     Declare @objectid int
     9     Set @objectid=object_id(@table_name)
    10     Select   
    11     col_name(@objectid,colid)  '主键字段'
    12     From  sysobjects         as o
    13     Inner Join sysindexes    as i On i.name=o.name 
    14     Inner Join sysindexkeys  as k On k.indid=i.indid
    15     Where 
    16     o.xtype = 'PK' and parent_obj=@objectid and k.id=@objectid