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

本文转自 梦在旅途 博客园博客,原文链接:http://www.cnblogs.com/zuowj/p/3940937.html  ,如需转载请自行联系原作者

相关文章
|
19天前
|
SQL NoSQL Java
Java使用sql查询mongodb
通过使用 MongoDB Connector for BI 和 JDBC,开发者可以在 Java 中使用 SQL 语法查询 MongoDB 数据库。这种方法对于熟悉 SQL 的团队非常有帮助,能够快速实现对 MongoDB 数据的操作。同时,也需要注意到这种方法的性能和功能限制,根据具体应用场景进行选择和优化。
64 9
|
1月前
|
SQL 存储 人工智能
Vanna:开源 AI 检索生成框架,自动生成精确的 SQL 查询
Vanna 是一个开源的 Python RAG(Retrieval-Augmented Generation)框架,能够基于大型语言模型(LLMs)为数据库生成精确的 SQL 查询。Vanna 支持多种 LLMs、向量数据库和 SQL 数据库,提供高准确性查询,同时确保数据库内容安全私密,不外泄。
148 7
Vanna:开源 AI 检索生成框架,自动生成精确的 SQL 查询
|
25天前
|
SQL Oracle 数据库
使用访问指导(SQL Access Advisor)优化数据库业务负载
本文介绍了Oracle的SQL访问指导(SQL Access Advisor)的应用场景及其使用方法。访问指导通过分析给定的工作负载,提供索引、物化视图和分区等方面的优化建议,帮助DBA提升数据库性能。具体步骤包括创建访问指导任务、创建工作负载、连接工作负载至访问指导、设置任务参数、运行访问指导、查看和应用优化建议。访问指导不仅针对单条SQL语句,还能综合考虑多条SQL语句的优化效果,为DBA提供全面的决策支持。
65 11
|
1月前
|
存储 缓存 网络协议
数据库执行查询请求的过程?
客户端发起TCP连接请求,服务端通过连接器验证主机信息、用户名及密码,验证通过后创建专用进程处理交互。服务端进程缓存以减少创建和销毁线程的开销。后续步骤包括缓存查询(8.0版后移除)、语法解析、查询优化及存储引擎调用,最终返回查询结果。
30 6
|
1月前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
1月前
|
SQL 监控 安全
SQL Servers审核提高数据库安全性
SQL Server审核是一种追踪和审查SQL Server上所有活动的机制,旨在检测潜在威胁和漏洞,监控服务器设置的更改。审核日志记录安全问题和数据泄露的详细信息,帮助管理员追踪数据库中的特定活动,确保数据安全和合规性。SQL Server审核分为服务器级和数据库级,涵盖登录、配置变更和数据操作等事件。审核工具如EventLog Analyzer提供实时监控和即时告警,帮助快速响应安全事件。
|
2月前
|
SQL Java
使用java在未知表字段情况下通过sql查询信息
使用java在未知表字段情况下通过sql查询信息
43 8
|
2月前
|
SQL 安全 PHP
PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全
本文深入探讨了PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全。
72 4
|
2月前
|
SQL 监控 关系型数据库
SQL语句当前及历史信息查询-performance schema的使用
本文介绍了如何使用MySQL的Performance Schema来获取SQL语句的当前和历史执行信息。Performance Schema默认在MySQL 8.0中启用,可以通过查询相关表来获取详细的SQL执行信息,包括当前执行的SQL、历史执行记录和统计汇总信息,从而快速定位和解决性能瓶颈。
|
1月前
|
SQL JavaScript 程序员
数据库LIKE查询屡试不爽?揭秘大多数人都忽视的秘密操作符!
本文分析了因数据库中的不可见空白字符导致的数据查询问题,探讨了问题的成因与特性,并提出了使用 SQL 语句修复问题的有效方案。同时,总结了避免类似问题的经验和注意事项。
35 0