MySQL中密码含特殊字符授权失败,如何正确用引号解决?

2026-04-30 21:200阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计813个文字,预计阅读时间需要4分钟。

MySQL中密码含特殊字符授权失败,如何正确用引号解决?

使用以下命令直接连接MySQL会失败,因为shell将特殊字符(如`@`、`/`、`:`)当作协议分隔符或路径分隔符处理,导致密码被截断或解析错误。这并不是MySQL不支持特殊字符,而是shell的行为导致的。

plaintext直接使用mysql -u user -p'pa@ss wd:123'这类命令会失败,因为shell将@、/、:当作协议分隔符或路径分隔符处理,导致密码被截断或解析错误。这不是MySQL不支持特殊字符,而是shell先吃掉了它们。

  • 必须用单引号包裹整个密码,且不能在单引号内嵌套单引号(即不能写'pa'ss'
  • 如果密码本身含单引号,改用双引号包裹,并对内部单引号转义:"pa'ss/wd"
  • 避免在命令行明文传密码——尤其脚本中,容易泄露;优先用mysql_config_editor或配置文件

mysql_config_editor安全存储含特殊字符的密码

这是最稳妥的方案:把密码加密存到用户家目录下的~/.mylogin.cnf,后续所有客户端工具自动读取,完全绕过shell解析。

阅读全文
标签:Mysql

本文共计813个文字,预计阅读时间需要4分钟。

MySQL中密码含特殊字符授权失败,如何正确用引号解决?

使用以下命令直接连接MySQL会失败,因为shell将特殊字符(如`@`、`/`、`:`)当作协议分隔符或路径分隔符处理,导致密码被截断或解析错误。这并不是MySQL不支持特殊字符,而是shell的行为导致的。

plaintext直接使用mysql -u user -p'pa@ss wd:123'这类命令会失败,因为shell将@、/、:当作协议分隔符或路径分隔符处理,导致密码被截断或解析错误。这不是MySQL不支持特殊字符,而是shell先吃掉了它们。

  • 必须用单引号包裹整个密码,且不能在单引号内嵌套单引号(即不能写'pa'ss'
  • 如果密码本身含单引号,改用双引号包裹,并对内部单引号转义:"pa'ss/wd"
  • 避免在命令行明文传密码——尤其脚本中,容易泄露;优先用mysql_config_editor或配置文件

mysql_config_editor安全存储含特殊字符的密码

这是最稳妥的方案:把密码加密存到用户家目录下的~/.mylogin.cnf,后续所有客户端工具自动读取,完全绕过shell解析。

阅读全文
标签:Mysql