如何在Unix/Linux进入不同数据库SQL命令行?

MySQL / MariaDB

  1. 安装客户端(如未安装)

    # Debian/Ubuntu
    sudo apt update && sudo apt install mysql-client
    # CentOS/RHEL
    sudo yum install mysql
  2. 连接数据库

    mysql -u 用户名 -p -h 主机地址 -P 端口
    • -u:用户名(如 root
    • -p:提示输入密码(密码输入时不可见)
    • -h:数据库服务器IP(本地可省略)
    • -P:端口号(默认3306可省略)
      示例

      mysql -u root -p  # 连接本地数据库
  3. 成功标志
    出现 mysql> 提示符,即可执行SQL命令(如 SHOW DATABASES;)。


PostgreSQL

  1. 安装客户端

    # Debian/Ubuntu
    sudo apt install postgresql-client
    # CentOS/RHEL
    sudo yum install postgresql
  2. 连接数据库

    psql -U 用户名 -d 数据库名 -h 主机地址 -p 端口
    • -U:用户名(默认用户 postgres
    • -d:数据库名(默认连接同名库)
      示例

      psql -U postgres -d testdb  # 连接本地testdb数据库
  3. 成功标志
    出现 数据库名=# 提示符(如 testdb=#)。


SQLite

  1. 安装SQLite

    # Debian/Ubuntu
    sudo apt install sqlite3
    # CentOS/RHEL
    sudo yum install sqlite
  2. 打开数据库文件

    sqlite3 数据库文件路径

    示例

    sqlite3 /data/mydb.db  # 打开现有数据库
    sqlite3 newdb.db       # 新建并打开数据库
  3. 成功标志
    出现 sqlite> 提示符。


Oracle Database

  1. 安装客户端
    需下载Oracle Instant Client(官网链接)。

  2. 连接数据库

    sqlplus 用户名/密码@主机地址:端口/服务名

    示例

    sqlplus scott/tiger@192.168.1.10:1521/ORCLCDB
  3. 成功标志
    出现 SQL> 提示符。


常见问题解决

  1. 连接被拒绝

    • 检查数据库服务是否运行:
      sudo systemctl status mysql    # MySQL
      sudo systemctl status postgresql # PostgreSQL
    • 确认防火墙开放端口(如3306、5432)。
  2. 命令未找到(Command not found)
    安装对应客户端(参考上文步骤)。

  3. 忘记密码

    • MySQL
      编辑配置文件 /etc/mysql/my.cnf,在 [mysqld] 下添加:

      skip-grant-tables

      重启服务后无密码登录,执行 ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码';

  4. 权限不足
    联系管理员授权:

    GRANT ALL PRIVILEGES ON *.* TO '用户名'@'主机';
    FLUSH PRIVILEGES;

安全注意事项

  1. 避免明文密码
    不要直接在命令中写密码(如 -p密码),使用 -p 交互输入。
  2. 使用SSH隧道
    远程连接时建议加密:

    ssh -L 63306:localhost:3306 user@remote-server
    mysql -u root -p -P 63306  # 通过隧道连接
  3. 最小权限原则
    日常操作避免使用 root 账户。

引用说明

  • MySQL官方文档:https://dev.mysql.com/doc/
  • PostgreSQL官方文档:https://www.postgresql.org/docs/
  • SQLite命令行工具:https://sqlite.org/cli.html
  • Oracle Instant Client:https://www.oracle.com/database/technologies/instant-client.html

提示:操作需管理员权限时,命令前加 sudo,生产环境修改配置前务必备份数据。

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

(0)
酷番叔酷番叔
上一篇 2025年7月8日 22:47
下一篇 2025年7月8日 22:57

相关推荐

  • /give指令如何秒刷满物品栏?

    在创造模式中按E键打开物品栏,直接拖取所需物品到背包,生存模式下使用/give @p 物品ID 数量命令获取物品,需开启作弊权限。

    2025年7月21日
    22700
  • a域名为何能打开b域名的页面?

    在互联网技术中,域名是网站的门牌号,而不同域名之间的页面跳转或内容加载是常见的Web开发需求,“a域名打开b域名的页面”这一场景涉及跨域请求、页面嵌入等技术实现,其背后需要兼顾功能需求与安全限制,本文将从技术实现、安全考量、应用场景及注意事项等方面,详细解析这一操作的核心要点,技术实现方式要实现a域名直接打开或……

    2025年11月30日
    12000
  • 视频识别如何守护安全帽安全带?

    在现代化工业生产与建筑施工领域,安全生产是企业发展的生命线,而个人防护装备(PPE)的正确佩戴则是保障一线作业人员安全的第一道,也是最重要的一道防线,安全帽与安全带作为防止高处坠落和物体打击事故的关键装备,其使用情况的监管历来是安全管理的重中之重,传统的人工巡检方式不仅耗时耗力,且存在监管盲区、易产生疏漏等问题……

    2025年11月20日
    12200
  • 国内三大公有区块链,究竟谁将引领行业发展?

    您未提供具体内容,请补充相关信息,以便我根据您的资料生成准确的回答。

    2026年2月26日
    7500
  • 安信华web应用防火墙有何核心优势?

    在数字化时代,Web应用已成为企业业务的核心载体,但同时也面临着日益严峻的安全威胁,SQL注入、跨站脚本(XSS)、跨站请求伪造(CSRF)等攻击手段层出不穷,一旦得手,可能导致数据泄露、业务中断甚至声誉受损,在此背景下,安信华Web应用防火墙(WAF)作为Web应用安全的第一道防线,凭借其先进的技术体系和全面……

    2025年12月11日
    11100

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信