查询表,视图,列等信息

 
---获取表和视图信息
select * from information_shcema.tables---查看当前数据库中当前用户有权限查看的所有表和视图信息

---获取视图信息
select * from information_schema.views

---获取列信息
select * from information_schema.columns
如果需要查看指定表或视图的列情况,可以使用下面的语句。
select 
 *
from
 information_schema.columns
where
 table_catalog='数据库名'
and 
 table_name='表名'

---获取视图中列的信息
select * from information_schema.view_column_usage


---获取列信息
select * from sys.columns

将sys.columns与系统视图sys.objects和sys.types关联,获得列的一些详细信息,例如
select
  o.name as 表名,
  c.name as 列名,
  t.name as 数据类型,
  c.max_length as 长度,
  c.precision as精度,
  c.scale as 小数位数,
  case c.is_nullable when 1 then '是' else '否' end as 是否允许空,
  case c.is_identity when 1 then '是' else '否' end as 标识列,
from
  sys.columns c inner join sys.objects o
on
  o.object_id=c.object_id 
inner join
  sys.types t
on
  c.system_type_id=t.system_type_id
where
  o.name='表名' and t.name<>'sysname'
order by
  c.column_id 
go

--获取视图中包含表的信息
select * from information_schema.view_table_usage
go
 
--获取所有数据库对象的信息
select * from sys.objects 

--绑定规则
exec sp_bindrule '规则名','对象名'
例如
exec sp_bindrule 'sexrule','employees.sex'

--解除绑定规则
exec sp_unbindrule '对象名'

--删除规则
在删除规则前,需要调用sp_unbindrule存储过程解除该规则的绑定,例如

exec sp_unbindrule 'employees.sex'
drop rule sexrule

--查看表的索引信息
exec sp_helpindex tb

--结合sys.indexes和sys.index_columns,sys.objects,sys.columns查询索引所属的表或视图的信息
select
  o.name as 表名,
  i.name as 索引名,
  c.name as 列名,
  i.type_desc as 类型描述,
  is_primary_key as 主键约束,
  is_unique_constraint as 唯一约束,
  is_disabled as 禁用
from
  sys.objects o 
inner join
  sys.indexes i
on
  i.object_id=o.object_id
inner join 
  sys.index_columns ic
on
  ic.index_id=i.index_id and ic.object_id=i.object_id
inner join
  sys.columns c
on
  ic.column_id=c.column_id and ic.object_id=c.object_id
go
--根据表名和列名查看索引信息
select object_Name(a.object_id) as TableName,a.Name as IndexName,c.Name as ColName, description=a.type_desc,a.is_unique,a.is_primary_key,a.is_unique_constraintfrom sys.indexes a join sys.index_columns b on a.Object_id=b.Object_id and a.index_id=b.index_id join sys.columns c on c.object_id=a.object_id and c.column_id=b.column_idwhere objectproperty(a.object_id,'IsUserTable')=1 and a.Object_id=object_id('表名') AND c.Name='列名'


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值