MySQL和 Oracle查看表信息

在日常Mysql和Oracle数据库使用时,经常使用到查看表、索引等信息,记录下来,方便备查。

MySQL 主要是使用 information_schema 信息表;

Oracle 主要是使用 各种视图,如user_ind_columns。

一、查看所有表

MySQL查看表命令

sql 复制代码
// 查看所有表
show tables;

Oracle 查看表命令

sql 复制代码
// 查看所有表
SELECT table_name FROM user_tables;
// 查看所有表和表注释
SELECT table_name,comments FROM all_tab_comments;
二、查看索引信息

MySQL 查看表索引命令

sql 复制代码
// 查看索引
show INDEX from table_name;

Oracle 查看表索引命令

根据 dba_indexes 和 内置视图 user_ind_columns

sql 复制代码
// dba_indexes 查看所有索引
SELECT
	table_name,
	index_type,
	index_name
FROM
	dba_indexes
WHERE
	table_name IN (
		SELECT
			table_name
		FROM
			user_tables
);

// 内置视图user_ind_columns 查看索引
SELECT
	*
FROM
	user_ind_columns
WHERE
	table_name IN (
		SELECT
			table_name
		FROM
			user_tables
	);
三、查询主键信息

MySQL 查看主键信息

sql 复制代码
SELECT
	kk.column_name,
	kk.constraint_name,
	kk.referenced_table_name,
	kk.referenced_column_name
FROM
	information_schema.table_constraints tt
JOIN information_schema.key_column_usage kk
ON tt.constraint_name = kk.constraint_name
WHERE
	tt.constraint_type = 'PRIMARY KEY';

Oracle 查看主键信息

user_cons_columns 表约束视图

sql 复制代码
SELECT
	cc.*
FROM
	user_cons_columns cc,
	user_constraints c
WHERE
	cc.constraint_name = c.constraint_name
AND c.constraint_type = 'P'
AND cc.table_name IN (
SELECT
			table_name
		FROM
			user_tables
);
四、查询列信息

MySQL 查看列信息

sql 复制代码
// 查询所有列信息
SELECT
	TABLE_NAME,
	COLUMN_NAME,
	DATA_TYPE,
	CHARACTER_MAXIMUM_LENGTH
FROM
	information_schema.`COLUMNS`;

Oracle 查看列信息

sql 复制代码
SELECT
	tt.*, cc.COMMENTS
FROM
	user_tab_columns tt,
	user_col_comments cc
WHERE
	tt.table_name = cc.table_name
AND tt.column_name = cc.column_name
AND tt.table_name IN (
SELECT
			table_name
		FROM
			user_tables
)
相关推荐
煎蛋学姐21 小时前
SSM基于J2EE的山西旅游网站的设计与实现iiqmx(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·数据库·java-ee·ssm 框架·山西旅游网站·在线预订系统
咸甜适中21 小时前
rust语言,将JSON中的所有值以字符串形式存储到sqlite数据库中(逐行注释)
数据库·rust·sqlite·json
树下水月21 小时前
python 连接hive2 数据库
开发语言·数据库·python
DARLING Zero two♡1 天前
用Rust构建一个OCR命令行工具
数据库·rust·ocr
IT教程资源C1 天前
(N_144)基于微信小程序在线订餐系统
mysql·vue·uniapp·前后端分离·订餐小程序·springboot订餐
蟹至之1 天前
增删查改基础(其三)—— 聚合函数、分组查询(group by与having)、内置函数
数据库·mysql·增删查改
LumenL1u1 天前
CentOS 7/8/9 上安装 MySQL 8.0+ 完整指南
linux·mysql
2501_941111241 天前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
Wang's Blog1 天前
MySQL: 数据库索引深度解析:B树与哈希索引的结构、应用与优化策略
数据库·b树·mysql
2501_941112141 天前
Python Web爬虫入门:使用Requests和BeautifulSoup
jvm·数据库·python