AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / server / Perguntas / 1075525
Accepted
Zak
Zak
Asked: 2021-08-25 08:13:12 +0800 CST2021-08-25 08:13:12 +0800 CST 2021-08-25 08:13:12 +0800 CST

Aviso do MySQL "O usuário existe", mas o usuário não está na tabela "usuário"

  • 772

Estou com esse problema há semanas. Não tenho ideia de onde procurar a seguir. Limpei, limpei, reiniciei MySQLo serviço, reiniciei o Ubuntuservidor. O que pode fazer com que isso WARNINGe o usuário não apareçam na usertabela? Eu também tentei DROP usere obter 0 rows affectedcomo resultado. Isso é frustrante além da crença! Onde mais as informações do usuário são armazenadas no esquema e como posso eliminá-las?

Captura de tela

ATUALIZAR

Quando eu grep o nome de usuário /var/lib/mysql/mysql, encontro o nome de usuário no db.MYDarquivo. Embora eu não possa editá-lo. Então eu sei que o nome de usuário existe em algum lugar OUTRO que não seja a tabela de usuários.

mysql
  • 1 1 respostas
  • 1722 Views

1 respostas

  • Voted
  1. Best Answer
    digijay
    2021-08-25T09:21:32+08:002021-08-25T09:21:32+08:00

    Isso acontece quando um usuário é criado e concedido privilégios e, em seguida, excluído do mysql.user em vez de ser descartado:

    Primeiro, crie um usuário admin_x@localhost:

    mysql> create user admin_x@localhost identified by 'abc123';
    Query OK, 0 rows affected (0.01 sec)
    

    Verifique se o usuário está em mysql.user:

    mysql> select user, host from mysql.user where user='admin_x';
    +---------+-----------+
    | user    | host      |
    +---------+-----------+
    | admin_x | localhost |
    +---------+-----------+
    1 row in set (0.01 sec)
    

    OK.

    Agora concedemos a este usuário acesso a db test:

    mysql> grant all on test.* to admin_x@localhost;
    Query OK, 0 rows affected (0.00 sec)
    

    E confira:

    mysql> show grants for admin_x@localhost;
    +-----------------------------------------------------------+
    | Grants for admin_x@localhost                              |
    +-----------------------------------------------------------+
    | GRANT ALL PRIVILEGES ON *.* TO 'admin_x'@'localhost'      |
    | GRANT ALL PRIVILEGES ON `test`.* TO 'admin_x'@'localhost' |
    +-----------------------------------------------------------+
    2 rows in set (0.00 sec)
    

    Agora exclua o usuário incorretamente de mysql.user:

    mysql> delete from mysql.user where user='admin_x';
    Query OK, 1 row affected (0.00 sec)
    

    E o usuário não está mais em mysql.user:

    mysql> select user from mysql.user where user='admin_x';
    Empty set (0.00 sec)
    

    Mas quando você tenta criá-lo novo, você recebe um erro:

    mysql> create user admin_x@localhost identified by 'abc123';
    ERROR 1396 (HY000): Operation CREATE USER failed for 'admin_x'@'localhost'
    

    Isso porque admin_x@localhostainda tem privilégios armazenados em mysql.db:

    mysql> select User from mysql.db where user='admin_x';
    +---------+
    | User    |
    +---------+
    | admin_x |
    +---------+
    1 row in set (0.00 sec)
    

    Agora, quando você descarta o usuário

    mysql> drop user admin_x@localhost;
    Query OK, 0 rows affected (0.00 sec)
    

    ele realmente se foi e você pode criá-lo novamente:

    mysql> create user admin_x@localhost identified by 'abc123';
    Query OK, 0 rows affected (0.00 sec)
    
    • 11

relate perguntas

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Você pode passar usuário/passar para autenticação básica HTTP em parâmetros de URL?

    • 5 respostas
  • Marko Smith

    Ping uma porta específica

    • 18 respostas
  • Marko Smith

    Verifique se a porta está aberta ou fechada em um servidor Linux?

    • 7 respostas
  • Marko Smith

    Como automatizar o login SSH com senha?

    • 10 respostas
  • Marko Smith

    Como posso dizer ao Git para Windows onde encontrar minha chave RSA privada?

    • 30 respostas
  • Marko Smith

    Qual é o nome de usuário/senha de superusuário padrão para postgres após uma nova instalação?

    • 5 respostas
  • Marko Smith

    Qual porta o SFTP usa?

    • 6 respostas
  • Marko Smith

    Linha de comando para listar usuários em um grupo do Windows Active Directory?

    • 9 respostas
  • Marko Smith

    O que é um arquivo Pem e como ele difere de outros formatos de arquivo de chave gerada pelo OpenSSL?

    • 3 respostas
  • Marko Smith

    Como determinar se uma variável bash está vazia?

    • 15 respostas
  • Martin Hope
    Davie Ping uma porta específica 2009-10-09 01:57:50 +0800 CST
  • Martin Hope
    kernel O scp pode copiar diretórios recursivamente? 2011-04-29 20:24:45 +0800 CST
  • Martin Hope
    Robert ssh retorna "Proprietário incorreto ou permissões em ~/.ssh/config" 2011-03-30 10:15:48 +0800 CST
  • Martin Hope
    Eonil Como automatizar o login SSH com senha? 2011-03-02 03:07:12 +0800 CST
  • Martin Hope
    gunwin Como lidar com um servidor comprometido? 2011-01-03 13:31:27 +0800 CST
  • Martin Hope
    Tom Feiner Como posso classificar a saída du -h por tamanho 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich O que é um arquivo Pem e como ele difere de outros formatos de arquivo de chave gerada pelo OpenSSL? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent Como determinar se uma variável bash está vazia? 2009-05-13 09:54:48 +0800 CST

Hot tag

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve