命令怎么查看一个数据库

在数据库管理中,通过命令行查看数据库信息是开发者和运维人员的基本技能,无论是调试查询、监控资源还是管理数据结构,都需要熟练掌握相关命令,不同数据库系统(如MySQL、PostgreSQL、SQL Server、MongoDB等)的查看命令存在差异,本文将详细介绍主流数据库的查看方法,并通过表格对比核心命令,帮助读者快速上手。

命令怎么查看一个数据库

关系型数据库查看命令

MySQL/MariaDB

MySQL作为最流行的开源关系型数据库,其查看命令主要通过SHOWSELECT实现。

  • 查看所有数据库SHOW DATABASES;(需具备SHOW DATABASES权限,普通用户可能仅能看到部分数据库)。
  • 查看当前数据库SELECT DATABASE();或执行USE database_name;后通过SELECT @@database;查看。
  • 查看数据库:进入目标数据库后,SHOW TABLES;列出所有表。
  • 查看表结构DESCRIBE table_name;SHOW COLUMNS FROM table_name;,返回字段名、数据类型、是否允许NULL、键类型(如PRI主键、UNI唯一键)等信息。
  • 查看表数据SELECT * FROM table_name LIMIT 10;(建议加LIMIT避免全表查询,尤其是大表)。
  • 查看数据库大小:通过系统表查询:
    SELECT 
      table_schema AS 'Database', 
      ROUND(SUM(data_length + index_length)/1024/1024, 2) AS 'Size(MB)' 
    FROM information_schema.tables 
    GROUP BY table_schema;

PostgreSQL

PostgreSQL的查看命令需结合系统视图和元命令(需在psql终端中使用)。

  • 查看所有数据库l(元命令)或SELECT datname FROM pg_database;(SQL查询)。
  • 查看当前数据库c database_name切换数据库后,执行dt查看表,或SELECT current_database();
  • 查看表结构d table_name显示字段、类型、约束(如主键、外键),或SELECT column_name, data_type, is_nullable FROM information_schema.columns WHERE table_name = 'table_name';
  • 查看表数据SELECT * FROM table_name LIMIT 10;,PostgreSQL支持EXPLAIN ANALYZE SELECT * FROM table_name;查看执行计划。
  • 查看数据库大小SELECT pg_database_size('database_name') AS 'Size(B)';SELECT pg_size_pretty(pg_database_size('database_name'));格式化输出。

SQL Server

SQL Server使用系统存储过程和系统视图查看信息。

命令怎么查看一个数据库

  • 查看所有数据库EXEC sp_databases;SELECT name FROM sys.databases;(包含系统数据库和用户数据库)。
  • 查看当前数据库SELECT DB_NAME();,切换数据库用USE database_name;
  • 查看表SELECT name FROM sys.tables;EXEC sp_tables;
  • 查看表结构EXEC sp_columns table_name;SELECT column_name, data_type, is_nullable FROM information_schema.columns WHERE table_name = 'table_name';
  • 查看表数据SELECT TOP 10 * FROM table_name;(SQL Server使用TOP限制行数)。
  • 查看数据库大小
    SELECT 
      name AS 'Database', 
      size/128.0 AS 'Size(MB)' 
    FROM sys.master_files 
    WHERE database_id = DB_ID('database_name');

非关系型数据库查看命令

MongoDB

作为文档型数据库,MongoDB通过mongosh shell操作。

  • 查看所有数据库show dbs;(仅显示包含数据的数据库)。
  • 查看当前数据库db;use database_name;切换后,db.getName();
  • 查看集合(表)show collections;db.getCollectionNames();
  • 查看集合数据db.collection_name.find().limit(10);(默认返回前20条,.pretty()可格式化JSON输出)。
  • 查看集合统计信息db.collection_name.stats();(包含文档数、存储大小、索引信息)。
  • 查看数据库状态db.stats();(显示数据库大小、集合数量等)。

Redis

Redis是键值型数据库,查看命令需结合数据类型。

  • 查看所有数据库SELECT 0-15(Redis默认16个数据库,编号0-15),INFO keyspaces查看各数据库统计信息。
  • 查看当前数据库键KEYS *;(生产环境慎用,可能阻塞服务器,推荐SCAN 0分页遍历)。
  • 查看键类型TYPE key_name;(返回string、hash、list等)。
  • 查看键值GET key_name;(字符串)、HGETALL key_name;(哈希)、LRANGE key_name 0 -1;(列表)。
  • 查看数据库大小DBSIZE;(返回当前数据库键数量)。

主流数据库查看命令对比表

数据库类型 查看所有数据库 查看当前数据库 查看表/集合 查看表/集合结构 查看数据
MySQL SHOW DATABASES; SELECT DATABASE(); SHOW TABLES; DESCRIBE table; SELECT * FROM table LIMIT 10;
PostgreSQL lSELECT datname FROM pg_database; c dbSELECT current_database(); dtSELECT name FROM sys.tables; d tableSELECT column_name FROM information_schema.columns; SELECT * FROM table LIMIT 10;
SQL Server EXEC sp_databases; SELECT DB_NAME(); EXEC sp_tables; EXEC sp_columns table; SELECT TOP 10 * FROM table;
MongoDB show dbs; db;use db; show collections; db.collection.stats(); db.collection.find().limit(10);
Redis INFO keyspaces; SELECT db; KEYS *;SCAN 0; TYPE key; GET key;/HGETALL key;

注意事项

  1. 权限控制:普通用户可能无法查看所有数据库或系统表(如MySQL的mysql系统库),需管理员授权。
  2. 性能影响:避免在大表上直接执行SELECT *KEYS *,可能导致内存溢出或服务阻塞,建议结合LIMITSCAN等分页操作。
  3. 工具差异:部分数据库需通过特定客户端查看(如PostgreSQL的psql、MongoDB的mongosh),确保环境配置正确。

相关问答FAQs

Q1:为什么执行SHOW DATABASES;时看不到所有数据库?
A:这通常是由于权限不足,普通用户默认只能看到自己有权限访问的数据库,若需查看所有数据库,需管理员授予SHOW DATABASES权限(MySQL中可通过GRANT SHOW DATABASES ON *.* TO 'user'@'host';授权),部分数据库(如PostgreSQL)的系统数据库(如postgrestemplate1)默认仅对超级用户可见。

命令怎么查看一个数据库

Q2:如何快速查看某个数据库的表数量和总数据量?
A:不同数据库方法不同:

  • MySQL
    SELECT 
      table_schema AS 'Database', 
      COUNT(table_name) AS 'Table Count', 
      ROUND(SUM(table_rows)/1000000, 2) AS 'Approximate Data(Million Rows)' 
    FROM information_schema.tables 
    WHERE table_schema = 'your_database_name' 
    GROUP BY table_schema;
  • PostgreSQL
    SELECT 
      current_database() AS 'Database', 
      COUNT(*) AS 'Table Count', 
      pg_size_pretty(pg_database_size(current_database())) AS 'Total Size';
  • MongoDB
    db.stats(); // 返回集合数量、文档数、存储大小等

    通过上述命令可快速掌握数据库规模,辅助容量规划。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/14408.html

(0)
酷番叔酷番叔
上一篇 2025年8月22日 10:00
下一篇 2025年8月22日 10:14

相关推荐

  • 安全mysql数组如何正确使用?

    在当今数据驱动的时代,MySQL作为最受欢迎的开源关系型数据库管理系统之一,广泛应用于各类Web应用和企业系统中,随着数据价值的提升,数据库安全问题也日益凸显,特别是在处理数组数据时,若操作不当,极易引发SQL注入、数据泄露等风险,本文将围绕“安全MySQL数组”这一主题,从数组存储、查询、更新及删除等环节,探……

    2025年12月10日
    10300
  • thinkpad怎么进入命令行界面

    inkPad进入命令行界面,可在系统启动时按F8选带命令提示符的安全模式

    2025年8月15日
    13200
  • 如何快速使用开始屏幕磁贴?

    进入Windows 8开始屏幕(按键盘 Win 键或点击屏幕左下角),直接输入 cmd(无需点击搜索框),系统自动显示搜索结果,在左侧找到 “命令提示符” 图标,单击打开即可进入标准模式,如需管理员权限:右键单击图标 → 选择 “以管理员身份运行”(底部工具栏会显示此选项),使用“运行”对话框(通用高效)按组合……

    2025年7月27日
    16800
  • 国内BI软件主要采用何种技术或编程语言开发?

    国内BI软件主要采用Java开发后端,前端使用JavaScript和HTML5,部分集成Python。

    2026年3月3日
    7100
  • 奥地利网站后缀是什么?

    奥地利网站后缀,即国家代码顶级域名(ccTLD),在互联网标识体系中扮演着独特角色,作为奥地利的数字身份象征,“.at”后缀不仅承载着国家信息,更成为连接全球用户与奥地利本地内容的重要桥梁,本文将从技术特性、注册规则、应用场景及发展现状等方面,全面解析这一域名体系的核心要素,技术基础与注册规则“.at”域名由奥……

    2025年12月6日
    11000

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信