通过系统数据库获取用户所有数据库中的视图、表、存储过程

所属分类: 数据库 / MsSql 阅读数: 158
收藏 0 赞 0 分享

复制代码 代码如下:

--设置sql 可以获取实例名称
sp_configure 'xp_cmdshell' , 1;
go
reconfigure;
go

--获取实例名
EXEC sys .xp_cmdshell 'sqlcmd -Lc'

--获取所有数据库
Select * FROM Master..SysDatabases order by Name

--获取数据库所有表
use yeekang ---数据库名称
select * from sysobjects where   type = 'U' order by name

--获取指定表字段
select * from syscolumns where id= OBJECT_ID('Userinfo' )

SELECT
表名 =case when a .colorder= 1 then d.name else '' end ,
表说明 =case when a .colorder= 1 then isnull(f .value, '') else '' end,
字段序号 =a. colorder,
字段名 =a. name,
标识 =case when COLUMNPROPERTY ( a .id, a.name ,'IsIdentity')= 1 then '√' else '' end ,
主键 =case when exists( SELECT 1 FROM sysobjects where xtype ='PK' and name in (
SELECT name FROM sysindexes WHERE indid in(
SELECT indid FROM sysindexkeys WHERE id = a .id AND colid =a. colid
))) then '√ ' else '' end,
类型 =b. name,
占用字节数 =a. length,
长度 =COLUMNPROPERTY( a.id ,a. name,'PRECISION' ),
小数位数 =isnull( COLUMNPROPERTY(a .id, a.name ,'Scale'), 0),
允许空 =case when a .isnullable= 1 then '√' else '' end,
默认值 =isnull( e.text ,''),
字段说明 =isnull( g.[value] ,'')

复制代码 代码如下:

FROM syscolumns a
left join systypes b on a. xusertype=b .xusertype
inner join sysobjects d on a. id=d .id and d .xtype= 'U' and d.name <>'dtproperties'
left join syscomments e on a. cdefault=e .id
left join sys. extended_properties g on a.id =g. major_id and a.colid =g. minor_id
left join sys. extended_properties f on d.id =f. major_id and f. minor_id=0
where a .id= OBJECT_ID('Userinfo' )
order by a. id,a .colorder


另一例:

在SQL Server数据库中每一个数据库都有一个sysobjects系统表,这个表里面存储了当前数据库的所有对象,包括对象表,用户表,视图,触发器,约束,默认值,日志,和存储过程的信。

先列一下这张表的一些字段名:

name  对象名
id       对象标识号
xtype  对象类型
uid      所有者对象的用户ID
parent_obj    父对象的对象标识号
crdate   对象的创建日期
ftcatid    为全文索引注册的所有用户表的全文目录标识符
schema_ver   版本号,
category  用于发布,约束和标识

看上上面的字段你应该已经清楚了吧...
xtype这个字段就是确定对象类型的...

如果你想获取数据库中所有的表信息,你可以写如下的查询语句:

复制代码 代码如下:

select * from sysobjects where xtype='u'

如果你想获取数据库中所有的存储过程的信息,你可以写如下的查询语句:

复制代码 代码如下:

select * from sysobjects where xtype='p'

如果你想获取数据库中所有的视图信息,你可以写如下的查询语句:

复制代码 代码如下:

select * from sysobjects where xtype='v'

如果你想获取数据库中所有的触发器信息,你可以写如下的查询语句:

复制代码 代码如下:

select * from sysobjects where xtype='tr'


获取SQL所有数据库名、所有表名、所有字段名

1.获取所有数据库名:

Select Name FROM Master..SysDatabases orDER BY Name

2.获取所有表名:

复制代码 代码如下:

Select Name FROM DatabaseName..SysObjects Where XType='U' orDER BY Name

XType='U':表示所有用户表;

XType='S':表示所有系统表;

3.获取所有字段名:

复制代码 代码如下:

Select Name FROM SysColumns Where id=Object_Id('TableName')

方法二。

复制代码 代码如下:

select   *   from   sys.databases    
select   *   from   information_schema.tables  
select   *   from   information_schema.columns where table_name='tablename'

更多精彩内容其他人还在看

SQL Server评估期已过问题的解决方法

这篇文章主要为大家详细介绍了SQL Server评估期已过问题的解决方法,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

sqlserver还原数据库的时候出现提示无法打开备份设备的解决方法(设备出现错误或设备脱)

今天在恢复数据库的时候,因为是异地部分还原,出现提示 无法打开备份设备 E:\自动备份\ufidau8xTmp\UFDATA.BAK 。设备出现错误或设备脱,这里分享一下解决方法,需要的朋友可以参考一下
收藏 0 赞 0 分享

SQL数据库存储过程示例解析

这篇文章主要针对SQL数据库存储过程示例进行解析,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

SQL Server 2012 安全概述

这篇文章给你概括介绍了SQL Server 2012里的基本安全概念。你学到了一些常见的数据威胁,探寻了SQL Server背后的设计理念,学习了在整个系列文章看到的一些安全术语,算是一篇比较非公式化的开篇,希望能够勾引起大家对于sql安全的兴趣
收藏 0 赞 0 分享

探讨select in 在postgresql的效率问题

这篇文章主要介绍了探讨select in 在postgresql的效率问题 的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

SQL Server 2012 身份验证(Authentication)

这篇SQL Server安全文章,我们学习了SQL Server里的多个验证选项。Windows集成身份验证是最安全的,但并不是都是可行的,微软多年来已经让SQL Server验证更加安全。
收藏 0 赞 0 分享

SQL性能优化之定位网络性能问题的方法(DEMO)

这篇文章主要介绍了SQL性能优化之定位网络性能问题的方法的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

SQL Server 2016里的sys.dm_exec_input_buffer的问题

这篇文章主要介绍了SQL Server 2016里的sys.dm_exec_input_buffer的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

SQL Server删除表及删除表中数据的方法

本文介绍SQL Server中如何删除表,如何删除表中的数据。在删除表数据时有delete和truncate两种方法,delete和truncate有什么区别呢
收藏 0 赞 0 分享

sqlserver 因为选定的用户拥有对象,所以无法除去该用户的解决方法

这篇文章主要介绍了sqlserver 因为选定的用户拥有对象,所以无法除去该用户,因为是附加数据库选择了与源服务器一样的用户导致
收藏 0 赞 0 分享
查看更多