注册
 找回密码
 注册
江西广告网
查看: 357|回复: 0
打印 上一主题 下一主题

sql中利用SP_KEYS来确定一个表格的关键键

[复制链接]

该用户从未签到

1
跳转到指定楼层
发表于 2009-1-18 17:16:07 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?注册

x
  当你需要找到一个表格是否有一个关键键,你可以使用系统的存储进程sp_pkeys。系统的存储进程有三个输入参数:      @table_name:这个是询问语句中表格的名字,在通配符没有被使用的时候它是一个必须使用的参数。   @table_owner:这个是表格系主.   @table_qualifier:这个是表格所在地的数据库名字 (这个很让人产生一种误解,因为你必须执行表格所在地的数据库中的这个进程)      sp_keys进程将返回这个信息:      TABLE_QUALIFIER   TABLE_OWNER   TABLE_NAME   COLUMN_NAME   KEY_SEQ   PK_NAME      同样的,你可以使用sp_keys系统的存储进程在关键键中找到表格。      下面的代码将会从North Wind的检索关键键的信息顺序表格中检索关键键:      USE NORTHWIND   GO   EXEC sp_pkeys @table_name = N'Orders', @table_owner = N'dbo', @table_qualifier = N'Northwind'   GO   SELECT TC.CONSTRAINT_CATALOG, TC.CONSTRAINT_SCHEMA, TC.TABLE_NAME, KCU.COLUMN_NAME, KCU.ORDINAL_POSITION, KCU.CONSTRAINT_NAME   FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS TC   JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE KCU   ON TC.TABLE_NAME = KCU.TABLE_NAME   AND TC.CONSTRAINT_NAME = KCU.CONSTRAINT_NAME   WHERE TC.TABLE_NAME = N'Orders' AND TC.CONSTRAINT_TYPE = N'PRIMARY KEY'   GO       <
您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表