`

SQL获取所有用户名,数据库名、所有表名、所有字段名及字段类型

阅读更多

1.获取所有用户名:
SELECT name FROM Sysusers where status='2' and islogin='1'
islogin='1'表示帐户
islogin='0'表示角色
status='2'表示用户帐户
status='0'表示糸统帐户
2.获取所有数据库名:
SELECT Name FROM Master..SysDatabases ORDER BY Name
3.获取所有表名
SELECT Name FROM DatabaseName..SysObjects Where XType='U' ORDER BY Name
XType='U':表示所有用户表;
XType='S':表示所有系统表;
4.获取所有字段名:
SELECT Name FROM SysColumns WHERE id=Object_Id('TableName')
5.获取数据库所有类型
select name from systypes
6.获取主键字段
SELECT   name FROM SysColumns WHERE id=Object_Id('表名') and colid=(select top 1 keyno from sysindexkeys where id=Object_Id('表名'))

7、获取字段类型

select a.name as [column],b.name as type from syscolumns a,systypes b where a.id=object_id('表名') and a.xtype=b.xtype
或者可以通过存储过程
exec sp_help 表名

8、取表结构

select column_name,data_type,character_maximum_length from information_schema.columns where table_name = '表名'


/****************************************************************************************************************************/

/*--获取连接SQL服务器的信息

所有连接本机的:操作的数据库名,计算机名,用户名,网卡物理地址,IP地址,程序名

--邹建 2003.11(引用请保留此信息)--*/

/*--调用示例
--显示所有本机的连接信息
exec p_getlinkinfo

--显示所有本机的连接信息,包含ip地址
exec p_getlinkinfo @includeip=1

--显示连接指定数据库的信息
exec p_getlinkinfo '客户资料'
--*/
create proc p_getlinkinfo
@dbname sysname=null, --要查询的数据库名,默认查询所有数据库的连接信息
@includeip bit=0 --是否显示IP地址,因为查询IP地址比较费时,所以增加此控制
as
declare @dbid int
set @dbid=db_id(@dbname)

create table #tb(id int identity(1,1),dbname sysname,hostname nchar(128),loginname nchar(128),net_address nchar(12),net_ip nvarchar(15),prog_name nchar(128))
insert into #tb(hostname,dbname,net_address,loginname,prog_name)
select distinct hostname,db_name(dbid),net_address,loginame,program_name from master..sysprocesses
where hostname<>'' and (@dbid is null or dbid=@dbid)

if @includeip=0 goto lb_show --如果不显示IP地址,就直接显示

declare @sql varchar(500),@hostname nchar(128),@id int
create table #ip(hostname nchar(128),a varchar(200))
declare tb cursor local for select distinct hostname from #tb
open tb
fetch next from tb into @hostname
while @@fetch_status=0
begin
set @sql='ping '+@hostname+' -a -n 1 -l 1'
insert #ip(a) exec master..xp_cmdshell @sql
update #ip set hostname=@hostname where hostname is null
fetch next from tb into @hostname
end

update #tb set net_ip=left(a,patindex('%:%',a)-1)
from #tb a inner join (
select hostname,a=substring(a,patindex('Ping statistics for %:%',a)+20,20) from #ip
where a like 'Ping statistics for %:%') b on a.hostname=b.hostname

lb_show:
select   id,dbname as '数据库名',hostname as '客户机名',loginname as '用户名'  
,net_address as '网卡物理地址',net_ip as 'IP地址',prog_name as '应用程序名称'   from   #tb

go 

 

分享到:
评论

相关推荐

    SQL获取数据库的数据库名,表名,存储过程

    #### 五、获取数据库的所有类型 要获取数据库中的所有数据类型,可以使用以下SQL语句: ```sql SELECT name FROM sys.types; ``` 对于较旧的SQL Server版本,可以使用: ```sql SELECT name FROM systypes; ``` ...

    java如何获得数据库表中各字段的字段名

    ### Java如何获得数据库表中各字段的字段名 在Java编程中,经常需要与数据库进行交互,例如查询、更新或删除等操作。其中一项常见需求是获取数据库表中的所有字段名称。这通常在动态生成报表或者需要根据数据库结构...

    SQL获取所有数据库名、表名、储存过程以及参数列表 (2).pdf

    以下是一些关键知识点,主要涉及如何获取SQL数据库中的各种元数据,如用户名、数据库名、表名、字段名以及主键信息。 1. **获取所有用户名**: 使用`SELECT name FROM Sysusers`语句,可以通过筛选`status='2'`和`...

    SQL获取所有数据库名、表名、储存过程以及参数列表.docx

    - 获取数据库中的所有类型:`SELECT name FROM systypes`。`systypes`视图包含数据库中所有数据类型的定义。 6. **主键字段获取**: - 获取表的主键字段:`SELECT name FROM SysColumns WHERE id=Object_Id('表名...

    SQL获取所有数据库名、表名、储存过程以及参数列表.pdf

    5. **获取数据库所有类型**: 使用`SELECT name FROM systypes`,这将列出所有可用的数据类型。 6. **获取主键字段**: 要找出表的主键字段,可以执行`SELECT name FROM SysColumns WHERE id=Object_Id('表名') and ...

    PL/SQL实现获得所有表名及列名到表

    本文将详细探讨如何使用PL/SQL来实现获取数据库中所有表名及其列名,并存储到一个特定的表中。 ### 一、理解需求与设计思路 #### 1. 需求分析: 我们的目标是创建一个PL/SQL程序,该程序能够遍历当前用户拥有的...

    任意数据库连接、表、字段名获取

    在IT行业中,数据库连接、表名获取以及字段名获取是常见的任务,特别是在开发数据库驱动的应用程序时。这里,我们关注的是使用C#编程语言在Visual Studio 2005环境下实现这一目标。"DBACESS"这个文件可能是实现这一...

    SQL建表查询附加取表名字段

    本文将详细介绍SQL建表查询的相关知识点,包括获取所有用户名、数据库名、表名、字段名、数据库类型、主键字段等信息,并且提供了附加数据库、分离数据库的操作命令。 获取所有用户名 在SQL Server中,我们可以使用...

    ASP获取数据库表名、库名、字段名的方法

    以下是ASP获取数据库表名、库名、字段名的方法的知识点总结。 首先,想要在ASP中操作SqlServer数据库,需要先建立数据库连接。可以使用ADODB(ActiveX Data Objects Database)组件来创建一个连接对象。例如,通过...

    VS2005下动态配置数据源、获取表名及字段名

    在本文中,我们将深入探讨如何在Visual Studio 2005 (VS2005)环境下,使用C#语言动态地配置数据源并获取数据库中的表名和字段名。这是一项重要的开发技能,特别是在需要创建灵活的数据驱动应用程序时。 首先,我们...

    MYSQL数据库取表名易语言源码

    易语言提供了处理结果集的方法,如获取结果行数、获取字段名和字段值等。 4. **异常处理**:在编写代码时,确保包含适当的错误处理机制,例如捕获可能的网络连接问题、权限错误或者SQL语法错误等。 5. **源码结构*...

    sql语句插入MySQL数据库操作指南

    在团队协作中,如果数据库表结构频繁变动,可以使用版本控制工具(如Git)来管理SQL脚本,确保每个人都能及时获取到最新的数据库变更。同时,可以利用Flyway或 Liquibase等数据库迁移工具来自动化这个过程,它们能...

    Oracle数据库常用sql语句的分类和常用函数.docx

    ALTER TABLE 表名 MODIFY (字段名 类型); ``` - **添加约束**: ```sql ALTER TABLE 表名 ADD CONSTRAINT 约束名 PRIMARY KEY (字段名); ALTER TABLE 表名 ADD CONSTRAINT 约束名 UNIQUE (字段名); ``` ####...

    SQL系统关键字--ddl等操作

    Create Table 表名 (字段名 数据类型, ...); ``` - ALTER:用于修改已存在的数据库或表结构。例如: ```sql Alter Table 表名 Add Column 新字段名 数据类型; Alter Table 表名 Drop Column 字段名; ``` -...

    从sqlserver数据库到MYSQL数据库转换操作指南

    在连接 MySQL 数据库之前,我们需要了解 MySQL 数据库的连接信息,包括主机名、用户名、密码、端口号等信息。 打开 Kettle,进入数据库连接页面,按照下图标记选择并输入数据库连接信息: 连接类型选择:MySQL ...

    易语言数据库字段求和

    对于字段求和,你可以使用"SELECT SUM(字段名) FROM 表名"的格式。比如,如果你有一个名为“sales”的表,字段名为“amount”,你可以构建如下的SQL语句:“SELECT SUM(amount) FROM sales”。 3. 使用“执行SQL”...

    将数据库数据生成excel并可供下载demo

    连接成功后,我们可以编写SQL查询语句来获取所需的数据。 描述中提到的"将数据库中的数据生成excel",这一步通常涉及到数据的查询和转换。查询结果通常是结构化的表格数据,如二维数组或DataFrame(在Python中)。...

    获取SQL-Server中的所有数据库用户,数据表,列,备注说明,主外键.docx

    本文将详细介绍如何获取SQL Server中的所有数据库用户、数据表、列、备注说明以及主外键信息。 首先,获取所有数据库用户通常涉及查询`sys.database_principals`系统视图,它包含了数据库中的所有安全主体,包括...

Global site tag (gtag.js) - Google Analytics