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

原文: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('表名'))

[综合网络资料整理]

1.获取所有数据库名:
   (1)、Select Name FROM Master..SysDatabases order by Name
2.获取所有表名:
   (1)、Select Name FROM SysObjects Where XType='U' orDER BY Name
           XType='U':表示所有用户表;
           XType='S':表示所有系统表;<?xml:namespace prefix="O"?>

   (2)、SELECT name FROM sysobjects WHERE type = 'U' AND sysstat = '83'

           注意:一般情况只需要type = 'U',但有时候会有系统表混在其中(不知道什么原因),加上后面一句后就能删除这些系统表了

3.获取所有字段名:
(1)、Select Name FROM SysColumns Where id=Object_Id('TableName')

(2)、SELECT syscolumns.name,systypes.name,syscolumns.isnullable,syscolumns.length FROM syscolumns, systypes WHERE syscolumns.xusertype = systypes.xusertype AND "syscolumns.id = object_id('tableName')

       注意点:
     (a)这里为了重点突出某些重要内容,选取了其中几项信息输出。
     (b)syscolumns表中只含有数据类型编号,要获取完整的名字需要从systypes表中找,一般用户使用的数据类型用xusertype对应比较好,不会出现一对多的情况。
     (c)syscolumns.length得到的是物理内存的长度,所以nvarchar和varchar等类型在数据库中的显示是这个的一半。

4、得到表中主键所包含的列名:

    SELECT syscolumns.name FROM syscolumns,sysobjects,sysindexes,sysindexkeys WHERE syscolumns.id = object_id('tablename') AND sysobjects.xtype = 'PK' AND sysobjects.parent_obj = syscolumns.id AND sysindexes.id = syscolumns.id AND sysobjects.name = sysindexes.name AND sysindexkeys.id = syscolumns.id AND sysindexkeys.indid = sysindexes.indid AND syscolumns.colid = sysindexkeys.colid

注意:这是在4张系统表中寻找的,关系比较复杂,大致可以表示为:
syscolumns中存有表中的列信息和表id,sysobjects表中存有主键名字(即PK_Table类似)和表id,sysindexes中存 有主键名字和表id和index编号,sysindexkeys中存有表id和index编号和列编号,一项一项对应起来后就能找到列名了。

 

另外的SQL代码



select syscolumns.name, systypes.name, syscolumns.length from syscolumns   

  left join systypes on syscolumns. xusertype =systypes. xusertype 

  where id=(select id from sysobjects where name='订货主档');

go;

或者用这样的写法,执行结果一样:



select syscolumns.name, systypes.name, syscolumns.length from syscolumns,systypes

where (syscolumns.id=object_id('订货主档') and syscolumns.xusertype=systypes.xusertype)

order by syscolumns.colorder;

go

执行结果:(字段只出现一次,正常)



订单号码    int 4

客户编号    nvarchar    10

员工编号    int 4

订单日期    datetime    8

要货日期    datetime    8

送货日期    datetime    8

送货方式    int 4

运费    money   8

收货人  nvarchar    80

送货地址    nvarchar    120

送货城市    nvarchar    30

送货行政区  nvarchar    30

送货邮政编码    nvarchar    20

送货国家地区    nvarchar    30

 

 

select syscolumns.name, systypes.name, syscolumns.length from syscolumns   

  left join systypes on syscolumns.xtype=systypes.xtype 

  where id=(select id from sysobjects where name='订货主档');

go;

执行结果:(部分字段出现两次,数据类型不同)



订单号码    int 4

客户编号    nvarchar   10

客户编号    sysname    10

员工编号    int 4

订单日期    datetime   8

订单日期    出生日期类型    8

要货日期    datetime   8

要货日期    出生日期类型    8

送货日期    datetime   8

送货日期    出生日期类型    8

送货方式    int 4

运费    money  8

运费    薪水类型    8

收货人  nvarchar   80

收货人  sysname    80

送货地址    nvarchar   120

送货地址    sysname    120

送货城市    nvarchar   30

送货城市    sysname    30

送货行政区  nvarchar   30

送货行政区  sysname    30

送货邮政编码    nvarchar   20

送货邮政编码    sysname    20

送货国家地区    nvarchar   30

送货国家地区    sysname    30

查询存储过程DepartmentSalaryInfo所有的信息,信息包含在系统视图syscolumnssystypes



select syscolumns.*, systypes.* from syscolumns   

  left join systypes on syscolumns.xusertype=systypes.xusertype 

  where id=(select id from sysobjects where name='DepartmentSalaryInfo');

go

 

 

exec   sp_procedure_params_rowset   @procedure_name   =   'DepartmentSalaryInfo';

go

执行结果:



北风贸易    dbo DepartmentSalaryInfo;1   @RETURN_VALUE 0   4   0   NULL   0   3   NULL   NULL   10    NULL   NULL   int int

北风贸易    dbo DepartmentSalaryInfo;1   @department   1   1   0   NULL   1   129 10  10  NULL    NULL   NULL   varchar    varchar

北风贸易    dbo DepartmentSalaryInfo;1   @average   2   2   0   NULL   1   6   NULL   NULL   19    NULL   NULL   money  money

北风贸易    dbo DepartmentSalaryInfo;1   @maximum   3   2   0   NULL   1   6   NULL   NULL   19    NULL   NULL   money  money

北风贸易    dbo DepartmentSalaryInfo;1   @minimum   4   2   0   NULL   1   6   NULL   NULL   19    NULL   NULL   money  money

 

--存储过程中的参数名,参数类型,参数长度

select syscolumns.name, systypes.name, syscolumns.length from syscolumns   

  left join systypes on syscolumns.xusertype=systypes.xusertype 

  where id=(select id from sysobjects where name='DepartmentSalaryInfo');

1:获取当前数据库中的所有用户表
select Name from sysobjects where xtype='u' and status>=0
2:获取某一个表的所有字段
select name from syscolumns where id=object_id('表名')
3:查询用户创建的所有数据库
select * from master..sysdatabases D where sid not in(select sid from
master..syslogins where name='sa')
或者
select dbid, name AS DB_NAME from master..sysdatabases where sid <> 0x01
4:查询某一个表的字段和数据类型
select column_name,data_type from information_schema.columns
where table_name = '表名'
[n].[标题]:
Select * From TableName Order By CustomerName
[n].[标题]:
8.如何修改数据库的名称:
sp_renamedb 'old_name', 'new_name'
9.只复制一个表结构,不复制数据
select top 0 * into [t1] from [t2]
10.连接远程数据库
select * from OPENDATASOURCE('SQLOLEDB','Data Source=远程ip;User
ID=sa;Password=密码').库名.dbo.表名

11.获取当前oracle数据库中的所有表
select table_name from user_tables

12 .获取当前oracle表中所有字段的类型

SELECT
      COLUMN_NAME,DATA_TYPE,DATA_LENGTH,NULLABLE

FROM
         USER_TAB_COLS where TABLE_NAME='teacher';

时间: 2024-08-06 21:53:56

SQL获取所有数据库名、表名、储存过程以及参数列表的相关文章

php mysql获取指定数据库所有表名

如果要显示mysql一个指定数据库的表名的话方法很简单,mysql提供了一个show tables命令,它返回的是一个数据,下面来看我做的详细实例,经过测试完全可用 */  代码如下 复制代码 $cn = mysql_connect('localhost','root','root'); mysql_select_db('test',$cn); print_r(get_tables()); /*输出结果 array (     [0] => abc     [1] => cn_user    

sql 查询所有数据库、表名、表字段总结

查询所有表: select id,name from sysobjects where type= 'u' order by name 查询所有数据库: use master select name from sysdatabases order by name 查询表中所有字段: select name from syscolumns where id = (select id from sysobjects where type = 'u' and name = '表名')

获取mysql数据库所有表名的php程序

其实我们用到的只是mysql教程 show用法的其实一个了,在mysql简单操作如下 show table 这样就可以显示所有表了,但在php教程中有所不同,我们看下面代码 $server = 'localhost'; $user = 'root'; $pass = ''; $dbname = 'dayanmei_com'; $conn = mysql_connect($server,$user,$pass); if(!$conn) die("数据库教程系统连接失败!"); mysql

oracle-DCN监听 java中获取到变化的表名为三个?

问题描述 DCN监听 java中获取到变化的表名为三个? 用的oracle DCN监听数据库变化的表,为什么打印出来的表名是??? 我写的哪里不对么?是在刚得到databaseChangeEvent的时候就已经是三个问号了, 但是rowid正常获取出来了,请求各位帮助,谢谢. package com.dtqy.dcn.test; import java.sql.SQLException; import java.util.Properties; import oracle.jdbc.Oracle

Dedecms数据库结构表名:dede_co_htmls

Dedecms数据库结构表名:dede_co_htmls字段说明如下: 表名:dede_co_htmls (ENGINE=MyISAM/CHARSET=gbk) 说明:采集信息表 字段名 说明描述 具体参数 typeid 栏目ID smallint(5) unsigned NOT NULL DEFAULT '0' , is export 是否导出 tinyint(1) NOT NULL DEFAULT '0' , litpic 链接所含图片 varchar(100) NOT NULL , res

Dedecms数据库结构表名:dede_arcmulti

Dedecms数据库结构表名:dede_arcmulti字段说明如下: 表名:dede_arcmulti (ENGINE=MyISAM/CHARSET=gbk) 说明:多页标记http://www.aliyun.com/zixun/aggregation/17326.html">存储数据表 字段名 说明描述 具体参数 attstr 属性字符串 text , uptime 更新日期 int(11) NOT NULL DEFAULT '0' , innertext 底层模板 varchar(2

Dedecms数据库结构表名:dede_stepselect

Dedecms数据库结构表名:dede_stepselect字段说明如下: 表名:dede_stepselect (ENGINE=MyISAM/CHARSET=gbk) 说明:类别组表 字段名 说明描述 具体参数 egroup 5603.html">缓存组名 char(20) DEFAULT NULL , issystem 是否系统内置 tinyint(1) unsigned NOT NULL DEFAULT '0' , itemhttp://www.aliyun.com/zixun/ag

Dedecms数据库结构表名:dede_tagindex

Dedecms数据库结构表名:dede_tagindex字段说明如下: 表名:dede_tagindex (ENGINE=MyISAM/CHARSET=gbk) 说明:tags 标签表 字段名 说明描述 具体参数 count 点击 int(10) unsigned NOT NULL DEFAULT '0' , typeid 栏目ID smallint(5) unsigned NOT NULL DEFAULT '0' , monthcc 月统计 int(10) unsigned NOT NULL

Dedecms数据库结构表名:dede_member_person

Dedecms数据库结构表名:dede_member_person字段说明如下: 表名:dede_member_person (ENGINE=MyISAM/CHARSET=gbk) 说明:个人详细信息表 字段名 说明描述 具体参数 tel 电话号 varchar(15) NOT NULL , nature 性格 set('性格外向','性格内向','活泼开朗','豪放不羁','患得患失','冲动','幽默','稳重','轻浮','沉默寡言','多愁善感','时喜时悲','附庸风雅','能说会道'