如果你一定要这样做的话,只能用添加主键: alter table tablename alter culomn culomnname primary key 非聚集索引 create index indexname on table(col) 聚集索引 create cluster index indexname on table(col)
SQL复制表结构的通用存储过程
-- Transfer对象的重要属性-- 1. 属性 属性名 类型 描述 --------------------------------- ------------------- -------------------- CopyAllDefaults Boolean 所有默认值 CopyAllObjects Boolean 所有对象 CopyAllRules Boolean 所有规则 CopyAllStoredProcedures Boolean 所有存储过程 CopyAllTables Boolean 所有表 CopyAllTriggers Boolean 所有触发器 CopyAllUserDefinedDatatypes Boolean 所有用户自定义类型 CopyAllViews Boolean 所有视图 CopyData Boolean 所有数据 DestDatabase String 目标对象数据库 DestLogin String 目标数据库登陆用户名 DestPassword String 目标数据库登陆密码 DestServer String 目标服务器 DestUseTrustedConnection Boolean 用户信任连接 DropDestObjectsFirst Boolean 是否先删除目标对象 IncludeDependencies Boolean 是否包含依靠对象 ScriptType Boolean 脚本类型 -- 2. 重要方法: 方法名称 功能描述 --------------------------- -------------------------- AddObject 增加对象 AddObjectByName 通过对象名称增加对象 if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[P_CopyDB]') and OBJECTPROPERTY(id, N'IsProcedure') = 1) drop procedure [dbo].[P_CopyDB] GO/*-- 在 SQLServer 中使用SQLDMO.Transfer 实现数据迁移 存储过程实现源数据库到目标数据库的对象和数据的复制 要求源数据库和目标数据库在同一服务器 如果是要实现不同服务器之间的复制,则需要增加验证信息 --邹建 2005.07(引用请保留此信息)--*//*--调用示例 CREATE DATABASE test EXEC P_CopyDB @Source_DB='northwind',@Des_DB='test' DROP DATABASE test --*/ CREATE PROCEDURE P_CopyDB @Des_DB sysname, --目标数据库 @Obj_Type nvarchar(4000)=N'',--复制的对象类型,可以是下列字符串列表: -- O 所有对象,D 默认值,R 规则,P 存储过程 -- T 表,TR 触发器,DT 用户定义数据类型 -- V 视图,DATA 数据,DEL 删除目标对象 @Source_DB sysname=N'', --源数据库 @ServerName sysname=N'', --服务器名 @UserName sysname=N'', --用户名,不指定则表示使用 Windows 身份登录 @pwd sysname=N'' --密码 AS SET NOCOUNT ON DECLARE @srvid int,@Dbid int,@S_dbid int,@D_dbid int,@TransferID int, @err int,@src varchar(255), @desc varchar(255)IF ISNULL(@ServerName,N'')=N'' SET @ServerName=@@SERVERNAME IF ISNULL(@Source_DB,N'')=N'' SET @Source_DB=DB_NAME() --创建sqldmo对象· EXEC @err=sp_oacreate 'sqldmo.sqlserver',@srvid OUT IF @err<>0 GOTO lb_Err--连接服务器 IF ISNULL(@UserName,N'')=N'' --使用 Windows 身份登录 BEGIN EXEC @err=sp_oasetproperty @srvid,'loginsecure',-1 IF @err<>0 GOTO lb_Err EXEC @err=sp_oamethod @srvid,'connect',NULL,@servername END ELSE EXEC @err=sp_oamethod @srvid,'connect',NULL,@servername,@UserName,@pwdIF @err<>0 GOTO lb_Err--获取数据库集 EXEC @err=sp_oagetproperty @srvid,'databases',@Dbid OUT IF @err<>0 GOTO lb_Err--选择源数据库 EXEC @err=sp_oamethod @Dbid,'item',@S_dbid OUT,@Source_DB IF @err<>0 GOTO lb_Err--选择目标数据库 EXEC @err=sp_oamethod @Dbid,'item',@D_dbid OUT,@Des_DB IF @err<>0 GOTO lb_Err--设置复制的对象 EXEC @err=sp_oacreate 'SQLDMO.Transfer',@TransferID OUT IF @err<>0 GOTO lb_Err--设置目标服务器信息 EXEC @err=sp_oasetproperty @TransferID,'DestServer',@ServerName IF @err<>0 GOTO lb_Err --设置连接用户 IF ISNULL(@UserName,N'')=N'' --使用 Windows 身份登录 BEGIN EXEC @err=sp_oasetproperty @TransferID,'DestUseTrustedConnection',1 IF @err<>0 GOTO lb_Err END ELSE BEGIN EXEC @err=sp_oasetproperty @TransferID,'DestLogin',@UserName IF @err<>0 GOTO lb_Err EXEC @err=sp_oasetproperty @TransferID,'DestPassword',@pwd IF @err<>0 GOTO lb_Err END --设置复制对象信息 EXEC @err=sp_oasetproperty @TransferID,'DestDatabase',@Des_DB IF @err<>0 GOTO lb_Err DECLARE tb CURSOR FAST_FORWARD LOCAL FOR SELECT Name FROM( SELECT KeyWord=N',D,', Name=N'CopyAllDefaults' UNION ALL SELECT KeyWord=N',O,', Name=N'CopyAllObjects' UNION ALL SELECT KeyWord=N',R,', Name=N'CopyAllRules' UNION ALL SELECT KeyWord=N',P,', Name=N'CopyAllStoredProcedures' UNION ALL SELECT KeyWord=N',T,', Name=N'CopyAllTables' UNION ALL SELECT KeyWord=N',TR,', Name=N'CopyAllTriggers' UNION ALL SELECT KeyWord=N',DT,', Name=N'CopyAllUserDefinedDatatypes' UNION ALL SELECT KeyWord=N',V,', Name=N'CopyAllViews' UNION ALL SELECT KeyWord=N',DATA,',Name=N'CopyData' UNION ALL SELECT KeyWord=N',DEL,', Name=N'DropDestObjectsFirst' )A WHERE CHARINDEX(KeyWord, CASE WHEN ISNULL(@Obj_Type,N'')='' THEN ',O,DATA,' ELSE @Obj_Type END)>0 OPEN tb FETCH tb INTO @src WHILE @@FETCH_STATUS=0 BEGIN EXEC @err=sp_oasetproperty @TransferID,@src,1 IF @err<>0 GOTO lb_Err FETCH tb INTO @src END CLOSE tb DEALLOCATE tb--复制对象 EXEC @err=sp_oamethod @S_dbid,'Transfer',null,@TransferID IF @err<>0 GOTO lb_Err--结束 SET @err=0 GOTO lb_Exit--错误处理 lb_Err: EXEC sp_oageterrorinfo NULL, @src OUT, @desc OUT RAISERROR(N'错误编号 %#x, 错误源 "%s", 错误描述 "%s"',16,1,@err,@src,@desc) RETURN -1lb_Exit: EXEC sp_OADestroy @Dbid EXEC sp_OADestroy @srvid EXEC sp_OADestroy @TransferID RETURN @err GO
在两个sql server数据库中复制对象CREATE PROC sp_CopyObject @S_DatabaseName sysname, --要复制对象的源数据库名 @D_DatabaseName sysname=NULL, --复制对象的目标数据库名,不指定则为当前库名 @TypeList nvarchar(50)=NULL --以逗号分隔的对象类型列表,只能是P/V/TR/IF/TF/FN之一或者是它们的组合.不指定是所有对象 AS IF DB_ID(@S_DatabaseName) IS NULL BEGIN RAISERROR('源数据库 "%s" 不存在',12,16,@S_DatabaseName) RETURN END IF DB_ID(@D_DatabaseName) IS NULL SET @D_DatabaseName=DB_NAME()DECLARE @sql nvarchar(4000) --处理对象类型列表 SET @sql=N'' SELECT @sql=@sql+N','+QUOTENAME(xtype,N'''') FROM( SELECT xtype=N'P' UNION ALL SELECT N'IF' UNION ALL SELECT xtype=N'V' UNION ALL SELECT N'TF' UNION ALL SELECT xtype=N'TR' UNION ALL SELECT N'FN' )a WHERE CHARINDEX(N','+xtype+N',',N','+@TypeList+N',')>0 IF @@ROWCOUNT=0 OR @sql='' SET @TypeList='N''P'',N''V'',N''TR'',N''IF'',''TF'',''FN''' ELSE SET @TypeList=STUFF(@sql,1,1,N'')--获取要复制对象(存储,视图,触发器)的数据 CREATE TABLE #(name sysname,xtype char(2),number smallint,colid smallint,text nvarchar(4000)) SET @sql=N' INSERT #(name,xtype,number,colid,text) SELECT o.name,o.xtype,m.number,m.colid,m.text FROM '+QUOTENAME(@S_DatabaseName)+N'.dbo.sysobjects o,' +QUOTENAME(@S_DatabaseName)+N'.dbo.syscomments m WHERE o.id=m.id AND m.encrypted=0 AND o.xtype IN('+@TypeList+N') AND o.status>=0' EXEC sp_executesql @sqlDECLARE tb CURSOR LOCAL FOR SELECT N'USE '+QUOTENAME(@D_DatabaseName)+N' DECLARE @name sysname,@number smallint SELECT @name='+QUOTENAME(name,N'''')+N', @number='+CAST(number as varchar)+N' DECLARE @1 nvarchar(4000),@2 nvarchar(4000),@3 nvarchar(4000),@4 nvarchar(1000) SELECT @1=N'''',@2=N'''',@3=N'''' SELECT @1=@1+N'',@''+RTRIM(colid)+N'' nvarchar(4000)'', @2=@2+N'',@''+RTRIM(colid) +N''=CASE colid WHEN ''+RTRIM(colid) +N'' THEN text ELSE @''+RTRIM(colid)+N'' END'', @3=@3+N''+@''+RTRIM(colid) FROM # WHERE name=@name AND number=@number ORDER BY colid SELECT @1=STUFF(@1,1,1,N''''), @2=STUFF(@2,1,1,N''''), @3=STUFF(@3,1,1,N''''), @4=N'' WHERE name=''+QUOTENAME(@name,N'''''''') +N'' AND number=''+RTRIM(@number) IF @NUMBER<2 AND EXISTS(SELECT * FROM sysobjects WHERE name=@name AND xtype=' +QUOTENAME(xtype,N'''')+N') DROP '+CASE xtype WHEN N'P' THEN N'PROC' WHEN N'V' THEN N'VIEW' WHEN N'TR' THEN N'TRIGGER' ELSE N'FUNCTION' END +N' '+QUOTENAME(name)+N' EXEC(N''DECLARE ''+@1+'' SELECT ''+@2+'' FROM # ''+@4+N'' EXEC(''+@3+'')'')' FROM # GROUP BY name,xtype,number OPEN tb FETCH tb INTO @sql WHILE @@FETCH_STATUS=0 BEGIN EXEC sp_executesql @sql FETCH tb INTO @sql END CLOSE tb DEALLOCATE tb
select * from sysindexes where id = object_id('tablename') sp_help tablename
use database --SqlServer2005--查询主键.外键.约束.视图.函数.存储过程.触发器 SELECT DISTINCT TOP 100 PERCENT o.xtype, CASE o.xtype WHEN 'X' THEN '扩展存储过程' WHEN 'TR' THEN '触发器' WHEN 'PK' THEN '主键' WHEN 'F' THEN '外键' WHEN 'C' THEN '约束' WHEN 'V' THEN '视图' WHEN 'FN' THEN '函数-标量' WHEN 'IF' THEN '函数-内嵌' WHEN 'TF' THEN '函数-表值' ELSE '存储过程' END AS 类型, o.name AS 对象名, o.crdate AS 创建时间, o.refdate AS 更改时间, c.text AS 声明语句 FROM dbo.sysobjects o LEFT OUTER JOIN dbo.syscomments c ON o.id = c.id WHERE (o.xtype IN ('X', 'TR', 'C', 'V', 'F', 'IF', 'TF', 'FN', 'P', 'PK')) AND (OBJECTPROPERTY(o.id, N'IsMSShipped') = 0) ORDER BY CASE o.xtype WHEN 'X' THEN '扩展存储过程' WHEN 'TR' THEN '触发器' WHEN 'PK' THEN '主键' WHEN 'F' THEN '外键' WHEN 'C' THEN '约束' WHEN 'V' THEN '视图' WHEN 'FN' THEN '函数-标量' WHEN 'IF' THEN '函数-内嵌' WHEN 'TF' THEN '函数-表值' ELSE '存储过程' END DESC
exec sp_helpindex table --表名
--2005 or 2008 select * from sys.indexes where id = object_id('table') --表名
alter table tablename alter culomn culomnname primary key
非聚集索引
create index indexname on table(col)
聚集索引
create cluster index indexname on table(col)
SQL复制表结构的通用存储过程
-- Transfer对象的重要属性-- 1. 属性 属性名 类型 描述
--------------------------------- ------------------- --------------------
CopyAllDefaults Boolean 所有默认值
CopyAllObjects Boolean 所有对象
CopyAllRules Boolean 所有规则
CopyAllStoredProcedures Boolean 所有存储过程
CopyAllTables Boolean 所有表
CopyAllTriggers Boolean 所有触发器
CopyAllUserDefinedDatatypes Boolean 所有用户自定义类型
CopyAllViews Boolean 所有视图
CopyData Boolean 所有数据
DestDatabase String 目标对象数据库
DestLogin String 目标数据库登陆用户名
DestPassword String 目标数据库登陆密码
DestServer String 目标服务器
DestUseTrustedConnection Boolean 用户信任连接
DropDestObjectsFirst Boolean 是否先删除目标对象
IncludeDependencies Boolean 是否包含依靠对象
ScriptType Boolean 脚本类型 -- 2. 重要方法: 方法名称 功能描述
--------------------------- --------------------------
AddObject 增加对象
AddObjectByName 通过对象名称增加对象 if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[P_CopyDB]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[P_CopyDB]
GO/*-- 在 SQLServer 中使用SQLDMO.Transfer 实现数据迁移
存储过程实现源数据库到目标数据库的对象和数据的复制
要求源数据库和目标数据库在同一服务器
如果是要实现不同服务器之间的复制,则需要增加验证信息
--邹建 2005.07(引用请保留此信息)--*//*--调用示例 CREATE DATABASE test
EXEC P_CopyDB @Source_DB='northwind',@Des_DB='test'
DROP DATABASE test
--*/
CREATE PROCEDURE P_CopyDB
@Des_DB sysname, --目标数据库
@Obj_Type nvarchar(4000)=N'',--复制的对象类型,可以是下列字符串列表:
-- O 所有对象,D 默认值,R 规则,P 存储过程
-- T 表,TR 触发器,DT 用户定义数据类型
-- V 视图,DATA 数据,DEL 删除目标对象
@Source_DB sysname=N'', --源数据库
@ServerName sysname=N'', --服务器名
@UserName sysname=N'', --用户名,不指定则表示使用 Windows 身份登录
@pwd sysname=N'' --密码
AS
SET NOCOUNT ON
DECLARE @srvid int,@Dbid int,@S_dbid int,@D_dbid int,@TransferID int,
@err int,@src varchar(255), @desc varchar(255)IF ISNULL(@ServerName,N'')=N'' SET @ServerName=@@SERVERNAME
IF ISNULL(@Source_DB,N'')=N'' SET @Source_DB=DB_NAME() --创建sqldmo对象·
EXEC @err=sp_oacreate 'sqldmo.sqlserver',@srvid OUT
IF @err<>0 GOTO lb_Err--连接服务器
IF ISNULL(@UserName,N'')=N'' --使用 Windows 身份登录
BEGIN
EXEC @err=sp_oasetproperty @srvid,'loginsecure',-1
IF @err<>0 GOTO lb_Err EXEC @err=sp_oamethod @srvid,'connect',NULL,@servername
END
ELSE
EXEC @err=sp_oamethod @srvid,'connect',NULL,@servername,@UserName,@pwdIF @err<>0 GOTO lb_Err--获取数据库集
EXEC @err=sp_oagetproperty @srvid,'databases',@Dbid OUT
IF @err<>0 GOTO lb_Err--选择源数据库
EXEC @err=sp_oamethod @Dbid,'item',@S_dbid OUT,@Source_DB
IF @err<>0 GOTO lb_Err--选择目标数据库
EXEC @err=sp_oamethod @Dbid,'item',@D_dbid OUT,@Des_DB
IF @err<>0 GOTO lb_Err--设置复制的对象
EXEC @err=sp_oacreate 'SQLDMO.Transfer',@TransferID OUT
IF @err<>0 GOTO lb_Err--设置目标服务器信息
EXEC @err=sp_oasetproperty @TransferID,'DestServer',@ServerName
IF @err<>0 GOTO lb_Err --设置连接用户
IF ISNULL(@UserName,N'')=N'' --使用 Windows 身份登录
BEGIN
EXEC @err=sp_oasetproperty @TransferID,'DestUseTrustedConnection',1
IF @err<>0 GOTO lb_Err
END
ELSE
BEGIN
EXEC @err=sp_oasetproperty @TransferID,'DestLogin',@UserName
IF @err<>0 GOTO lb_Err EXEC @err=sp_oasetproperty @TransferID,'DestPassword',@pwd
IF @err<>0 GOTO lb_Err
END --设置复制对象信息
EXEC @err=sp_oasetproperty @TransferID,'DestDatabase',@Des_DB
IF @err<>0 GOTO lb_Err DECLARE tb CURSOR FAST_FORWARD LOCAL
FOR
SELECT Name FROM(
SELECT KeyWord=N',D,', Name=N'CopyAllDefaults' UNION ALL
SELECT KeyWord=N',O,', Name=N'CopyAllObjects' UNION ALL
SELECT KeyWord=N',R,', Name=N'CopyAllRules' UNION ALL
SELECT KeyWord=N',P,', Name=N'CopyAllStoredProcedures' UNION ALL
SELECT KeyWord=N',T,', Name=N'CopyAllTables' UNION ALL
SELECT KeyWord=N',TR,', Name=N'CopyAllTriggers' UNION ALL
SELECT KeyWord=N',DT,', Name=N'CopyAllUserDefinedDatatypes' UNION ALL
SELECT KeyWord=N',V,', Name=N'CopyAllViews' UNION ALL
SELECT KeyWord=N',DATA,',Name=N'CopyData' UNION ALL
SELECT KeyWord=N',DEL,', Name=N'DropDestObjectsFirst'
)A WHERE CHARINDEX(KeyWord,
CASE WHEN ISNULL(@Obj_Type,N'')='' THEN ',O,DATA,' ELSE @Obj_Type END)>0
OPEN tb
FETCH tb INTO @src
WHILE @@FETCH_STATUS=0
BEGIN
EXEC @err=sp_oasetproperty @TransferID,@src,1
IF @err<>0 GOTO lb_Err
FETCH tb INTO @src
END
CLOSE tb
DEALLOCATE tb--复制对象
EXEC @err=sp_oamethod @S_dbid,'Transfer',null,@TransferID
IF @err<>0 GOTO lb_Err--结束
SET @err=0
GOTO lb_Exit--错误处理
lb_Err:
EXEC sp_oageterrorinfo NULL, @src OUT, @desc OUT
RAISERROR(N'错误编号 %#x, 错误源 "%s", 错误描述 "%s"',16,1,@err,@src,@desc)
RETURN -1lb_Exit:
EXEC sp_OADestroy @Dbid
EXEC sp_OADestroy @srvid
EXEC sp_OADestroy @TransferID
RETURN @err
GO
那樣則需要判斷原始表的主鍵和索引,還有Default選項等。
還是比較麻煩的,可以嘗試在系統表里進行查找后處理。
@S_DatabaseName sysname, --要复制对象的源数据库名
@D_DatabaseName sysname=NULL, --复制对象的目标数据库名,不指定则为当前库名
@TypeList nvarchar(50)=NULL --以逗号分隔的对象类型列表,只能是P/V/TR/IF/TF/FN之一或者是它们的组合.不指定是所有对象
AS
IF DB_ID(@S_DatabaseName) IS NULL
BEGIN
RAISERROR('源数据库 "%s" 不存在',12,16,@S_DatabaseName)
RETURN
END
IF DB_ID(@D_DatabaseName) IS NULL SET @D_DatabaseName=DB_NAME()DECLARE @sql nvarchar(4000)
--处理对象类型列表
SET @sql=N''
SELECT @sql=@sql+N','+QUOTENAME(xtype,N'''')
FROM(
SELECT xtype=N'P' UNION ALL SELECT N'IF' UNION ALL
SELECT xtype=N'V' UNION ALL SELECT N'TF' UNION ALL
SELECT xtype=N'TR' UNION ALL SELECT N'FN'
)a WHERE CHARINDEX(N','+xtype+N',',N','+@TypeList+N',')>0
IF @@ROWCOUNT=0 OR @sql=''
SET @TypeList='N''P'',N''V'',N''TR'',N''IF'',''TF'',''FN'''
ELSE
SET @TypeList=STUFF(@sql,1,1,N'')--获取要复制对象(存储,视图,触发器)的数据
CREATE TABLE #(name sysname,xtype char(2),number smallint,colid smallint,text nvarchar(4000))
SET @sql=N'
INSERT #(name,xtype,number,colid,text)
SELECT o.name,o.xtype,m.number,m.colid,m.text
FROM '+QUOTENAME(@S_DatabaseName)+N'.dbo.sysobjects o,'
+QUOTENAME(@S_DatabaseName)+N'.dbo.syscomments m
WHERE o.id=m.id
AND m.encrypted=0
AND o.xtype IN('+@TypeList+N')
AND o.status>=0'
EXEC sp_executesql @sqlDECLARE tb CURSOR LOCAL
FOR
SELECT N'USE '+QUOTENAME(@D_DatabaseName)+N'
DECLARE @name sysname,@number smallint
SELECT @name='+QUOTENAME(name,N'''')+N',
@number='+CAST(number as varchar)+N'
DECLARE @1 nvarchar(4000),@2 nvarchar(4000),@3 nvarchar(4000),@4 nvarchar(1000)
SELECT @1=N'''',@2=N'''',@3=N''''
SELECT @1=@1+N'',@''+RTRIM(colid)+N'' nvarchar(4000)'',
@2=@2+N'',@''+RTRIM(colid)
+N''=CASE colid WHEN ''+RTRIM(colid)
+N'' THEN text ELSE @''+RTRIM(colid)+N'' END'',
@3=@3+N''+@''+RTRIM(colid)
FROM #
WHERE name=@name AND number=@number
ORDER BY colid
SELECT @1=STUFF(@1,1,1,N''''),
@2=STUFF(@2,1,1,N''''),
@3=STUFF(@3,1,1,N''''),
@4=N'' WHERE name=''+QUOTENAME(@name,N'''''''')
+N'' AND number=''+RTRIM(@number)
IF @NUMBER<2 AND EXISTS(SELECT * FROM sysobjects WHERE name=@name AND xtype='
+QUOTENAME(xtype,N'''')+N') DROP '+CASE xtype
WHEN N'P' THEN N'PROC'
WHEN N'V' THEN N'VIEW'
WHEN N'TR' THEN N'TRIGGER'
ELSE N'FUNCTION' END
+N' '+QUOTENAME(name)+N'
EXEC(N''DECLARE ''+@1+''
SELECT ''+@2+'' FROM # ''+@4+N''
EXEC(''+@3+'')'')'
FROM #
GROUP BY name,xtype,number
OPEN tb
FETCH tb INTO @sql
WHILE @@FETCH_STATUS=0
BEGIN
EXEC sp_executesql @sql
FETCH tb INTO @sql
END
CLOSE tb
DEALLOCATE tb
select * from sysindexes where id = object_id('tablename')
sp_help tablename
--SqlServer2005--查询主键.外键.约束.视图.函数.存储过程.触发器
SELECT DISTINCT TOP 100 PERCENT o.xtype, CASE o.xtype WHEN 'X' THEN '扩展存储过程' WHEN 'TR' THEN '触发器' WHEN 'PK' THEN '主键' WHEN 'F' THEN '外键' WHEN 'C' THEN '约束' WHEN 'V' THEN '视图' WHEN 'FN' THEN '函数-标量' WHEN 'IF' THEN '函数-内嵌' WHEN 'TF' THEN '函数-表值' ELSE '存储过程' END AS 类型, o.name AS 对象名, o.crdate AS 创建时间, o.refdate AS 更改时间, c.text AS 声明语句 FROM dbo.sysobjects o LEFT OUTER JOIN dbo.syscomments c ON o.id = c.id WHERE (o.xtype IN ('X', 'TR', 'C', 'V', 'F', 'IF', 'TF', 'FN', 'P', 'PK')) AND (OBJECTPROPERTY(o.id, N'IsMSShipped') = 0) ORDER BY CASE o.xtype WHEN 'X' THEN '扩展存储过程' WHEN 'TR' THEN '触发器' WHEN 'PK' THEN '主键' WHEN 'F' THEN '外键' WHEN 'C' THEN '约束' WHEN 'V' THEN '视图' WHEN 'FN' THEN '函数-标量' WHEN 'IF' THEN '函数-内嵌' WHEN 'TF' THEN '函数-表值' ELSE '存储过程' END DESC
--2005 or 2008
select * from sys.indexes where id = object_id('table') --表名