"Si un trabajador quiere hacer bien su trabajo, primero debe afilar sus herramientas." - Confucio, "Las Analectas de Confucio. Lu Linggong"
Página delantera > Programación > Cómo solucionar problemas de la función CONTRASEÑA en MySQL Server 8.0: una guía de sintaxis

Cómo solucionar problemas de la función CONTRASEÑA en MySQL Server 8.0: una guía de sintaxis

Publicado el 2024-11-19
Navegar:900

How to Fix PASSWORD Function Issues in MySQL Server 8.0: A Syntax Guide

Solucionar problemas de la función CONTRASEÑA en MySQL Server 8.0

Al intentar ejecutar la función CONTRASEÑA en MySQL Server versión 8.0.12, ciertos escenarios pueden desencadenar un error. Este artículo tiene como objetivo abordar estos problemas y proporcionar una solución viable.

Código de error 1064

Si encuentra el error "Código de error: 1064. Tiene un error en su sintaxis SQL...", indica un problema con la sintaxis de su consulta. Específicamente, la sintaxis de la función CONTRASEÑA ha cambiado en MySQL Server versión 8.0.

Nueva sintaxis

Con MySQL Server 8.0, la función CONTRASEÑA ha quedado obsoleta y reemplazada por una diferente. mecanismo de hash. Para mantener la compatibilidad, debe utilizar la siguiente sintaxis para generar un hash equivalente al producido por la función PASSWORD en versiones anteriores:

CONCAT('*', UPPER(SHA1(UNHEX(SHA1('my_password')))))

Ejemplo

En la consulta proporcionada, "pwd = PASSWORD('2018')" representa la comparación de la columna "pwd" con una contraseña estática. Para recuperar usuarios con la contraseña '2018' usando la nueva sintaxis, puede modificar la consulta de la siguiente manera:

SELECT * 
FROM users 
WHERE login = 'FABIO' 
  AND pwd = CONCAT('*', UPPER(SHA1(UNHEX(SHA1('2018')))))
LIMIT 0, 50000
Último tutorial Más>

Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.

Copyright© 2022 湘ICP备2022001581号-3