MySQL中密码含特殊字符授权失败,如何正确用引号解决?
- 内容介绍
- 文章标签
- 相关推荐
本文共计813个文字,预计阅读时间需要4分钟。
使用以下命令直接连接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解析。
本文共计813个文字,预计阅读时间需要4分钟。
使用以下命令直接连接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解析。

