sql语句查询数据库表结构信息

开发中经常用到查询指定表及其字段的信息,以下是我整理的SQL语句查询方法,供自己平时使用也提供给大家参考!

1.适用MS SQL SERVER:

 1 SELECT
 2 表名 = case when a.colorder=1 then d.name else ‘‘ end,
 3 表说明 = case when a.colorder=1 then isnull(f.value,‘‘) else ‘‘ end,
 4 字段序号 = a.colorder,
 5 字段名 = a.name,
 6 标识 = case when COLUMNPROPERTY( a.id,a.name,‘IsIdentity‘)=1 then ‘√‘else ‘‘ end,
 7 主键 = case when exists(SELECT 1 FROM sysobjects where xtype=‘PK‘ and parent_obj=a.id and name in (
 8 SELECT name FROM sysindexes WHERE indid in(
 9 SELECT indid FROM sysindexkeys WHERE id = a.id AND colid=a.colid))) then ‘√‘ else ‘‘ end,
10 类型 = b.name,
11 占用字节数 = a.length,
12 长度 = COLUMNPROPERTY(a.id,a.name,‘PRECISION‘),
13 小数位数 = isnull(COLUMNPROPERTY(a.id,a.name,‘Scale‘),0),
14 允许空 = case when a.isnullable=1 then ‘√‘else ‘‘ end,
15 默认值 = isnull(e.text,‘‘),
16 字段说明 = isnull(g.[value],‘‘)
17 FROM
18 syscolumns a
19 left join
20 systypes b
21 on
22 a.xusertype=b.xusertype
23 inner join
24 sysobjects d
25 on
26 a.id=d.id and d.xtype=‘U‘ and d.name<>‘dtproperties‘
27 left join
28 syscomments e
29 on
30 a.cdefault=e.id
31 left join
32 sys.extended_properties g
33 on
34 --a.id=g.id and a.colid=g.smallid
35 a.id=g.major_id and a.colid=g.Minor_id
36 left join
37 sys.extended_properties f
38 on
39 --d.id=f.id and f.smallid=0
40 d.id=f.major_id and f.Minor_id=0
41 where
42 d.name=‘表名‘ --如果只查询指定表,加上此条件
43 order by
44 a.id,a.colorder

2.适用ORACLE:

 1 SELECT
 2 USER_TAB_COLS.TABLE_NAME as 表名,
 3 user_tab_comments.comments as 表备注,
 4 USER_TAB_COLS.COLUMN_ID as 列序号,
 5 user_col_comments.comments as 列备注,
 6 USER_TAB_COLS.COLUMN_NAME as 列名 ,
 7 USER_TAB_COLS.DATA_TYPE as 数据类型,
 8 USER_TAB_COLS.DATA_LENGTH as 长度,
 9 USER_TAB_COLS.NULLABLE as 是否为空,
10 user_cons_columns.constraint_name as 约束名,
11 user_constraints.constraint_type as 主键
12 FROM USER_TAB_COLS inner join user_col_comments on
13 user_col_comments.TABLE_NAME=USER_TAB_COLS.TABLE_NAME
14 and user_col_comments.COLUMN_NAME=USER_TAB_COLS.COLUMN_NAME
15 INNER join user_cons_columns on user_cons_columns.table_name=USER_TAB_COLS.table_name
16 INNER join user_constraints on user_constraints.table_name=USER_TAB_COLS.table_name and user_constraints.constraint_name=user_cons_columns.constraint_name
17 inner join user_tab_comments on USER_TAB_COLS.TABLE_NAME=user_tab_comments.TABLE_NAME
18 WHERE USER_TAB_COLS.table_name=‘表名‘
19 ORDER BY USER_TAB_COLS.TABLE_NAME

原文其它网址:http://www.zuowenjun.cn/post/2014/08/28/26.html

时间: 2024-10-10 03:49:30

sql语句查询数据库表结构信息的相关文章

sql语句查询同一表内多字段同时重复的记录 sql数据库重复记录删除

分享下用sql语句删除数据库中重复记录的方法.比如现在有一人员表 (表名:peosons) 若想将姓名.身份证号.住址这三个字段完全相同的记录查询出来select p1.* from persons p1,persons p2 where p1.id<>p2.id and p1.cardid = p2.cardid and p1.pname = p2.pname and p1.address = p2.address可以实现上述效果.几个删除重复记录的SQL语句 1.用rowid方法2.用gr

Java 通过JDBC查询数据库表结构(字段名称,类型,长度等)

Java 通过JDBC查询数据库表结构(字段名称,类型,长度等) 发布者:唛唛家的豆子 时间:2012-11-20 17:54:02 在JDBCPreparedStatement.executeQuery().getMetaData();后,我们可以通过ResultSetMetaData对象查询返回结果集的源数据信息,也就是表结构信息. 示例代码如下: package astar.sutil.db; import java.sql.Connection; import java.sql.Driv

mssqlserver 查询数据库表结构语句

查询指定表结构的表名.列名.类型.说明.字段长度 select o.name as tableName,c.name as columnName,t.name as columnType,p.value as columnDescription,c.prec from  sysobjects o left join syscolumns c  on o.id=c.idleft join sys.extended_properties p on p.major_id=c.id and p.mino

关于oracle sql语句查询时表名和字段名要加双引号的问题

oracle初学者一般会遇到这个问题. 用navicat可视化创建了表,可是就是不能查到! 后来发现②语句可以查询到 ①select * from user; 但是,我们如果给user加上双引号就可以查到了! ②select * from "user"; 难道oracle跟mysql等不同,查询时候一定要加双引号?那这样不是很麻烦!于是经过查找资料得出如下结论: 1.oracle表和字段是有大小写的区别.oracle默认是大写,如果我们用双引号括起来的就区分大小写,如果没有,系统会自动

关于oracle sql语句查询时 表名和字段名要加双引號的问题具体解释

  作为oracle的刚開始学习的人相信大家一定会遇到这个问题.如图:          明明就是navicat可视化创建了表,但是就是不能查到!这个为什么呢?           select * from user;           可是,我们假设给user加上双引號就不一样了!   select * from "user"; 却能够等到以下的结果.如图:          到这里我想大家肯定会说:难道oracle跟mysql等不同,查询时候一定要加双引號?那这样不是非常麻烦!

【Access2003】表的新建、用sql语句查询;关闭警告信息;修改数据库密码;修复数据库

一.表的新建 打开Access2003只有一个数据库控制器,选择使用设计器创建表,可以图形化设置一个表的 对某个字段按右键可以设置为主键 之后把所有字段弄好之后,按Ctrl+s保存, 你可以会发现在数据库控制器中多出一张表.如同Excel那样编辑就可以了.在ASP控制Access数据库也可以. 二.表的查询 在数据库控制器中选择"查询"一项,选择"在设计视图中创建查询",弹出的对话框中选择"关闭",之后,在空白的灰色区域点击右键.选择SQL视图.

Sql Server 导出数据库表结构的SQL查询语句

1 --导出数据库所有表 2 3 SELECT 4 表名 = Case When A.colorder=1 Then D.name Else '' End, 5 表说明 = Case When A.colorder=1 Then isnull(F.value,'') Else '' End, 6 字段序号 = A.colorder, 7 字段名 = A.name, 8 字段说明 = isnull(G.[value],''), 9 标识 = Case When COLUMNPROPERTY( A.

sql语句中---删除表结构drop,truncate和delete的异同点

参考别人总结,此内容仅供自己学习 一.sql中的语法 1.drop table 表名称                                      eg:drop table dbo.Sys_Test 2.truncate table 表名称                                eg:truncate table dbo.Sys_Test 3.delete from 表名称 where  列名称=值       eg:delete from dbo.Sys

sql语句对数据库表进行加锁和解锁

锁是数据库中的一个非常重要的概念,它主要用于多用户环境下保证数据库完整性和一致性. 我们知道,多个用户能够同时操纵同一个数据库中的数据,会发生数据不一致现象.即如果没有锁定且多个用户同时访问一个数据库,则当他们的事务同时使用相同的数据时可能会发生问题.这些问题包括:丢失更新.脏读.不可重复读和幻觉读: 1.当两个或多个事务选择同一行,然后基于最初选定的值更新该行时,会发生丢失更新问题.每个事务都不知道其它事务的存在.最后的更新将重写由其它事务所做的更新,这将导致数据丢失.例如,两个编辑人员制作了