Trusted WordPress tutorials, when you need them most.
Beginner’s Guide to WordPress
Copa WPB
25 Million+
Websites using our plugins
16+
Years of WordPress experience
3000+
WordPress tutorials
by experts

Cómo añadir un usuario administrador a la base de datos de WordPress mediante MySQL

Nota editorial: Ganamos una comisión de los enlaces de socios en WPBeginner. Las comisiones no afectan a las opiniones o evaluaciones de nuestros editores. Más información sobre Proceso editorial.

¿Te has quedado fuera de tu sitio web WordPress?

A veces, los hackers te bloquean tu propio sitio web borrando tu cuenta de administrador de la base de datos.

En este artículo, le mostraremos cómo añadir un usuario administrador a la base de datos de WordPress a través de MySQL para que pueda recuperar su acceso.

How to Add an Admin User to the WordPress Database via MySQL

¿Por qué añadir un usuario administrador a la base de datos de WordPress a través de MySQL?

Una vez nos encontramos con un problema en el que el sitio de un usuario fue hackeado, y su cuenta de administrador fue borrada de la base de datos. Esto bloqueó su sitio web WordPress.

Pudimos ayudarles a acceder a su sitio web creando un nuevo usuario administrador directamente en el sitio web de WordPress. Para ello, utilizamos phpMyAdmin, una herramienta web que permite gestionar bases de datos MySQL desde el navegador.

Si te encuentras bloqueado en tu área de administrador de WordPress debido a hackers o simplemente porque olvidaste tu contraseña, entonces puedes hacer lo mismo.

Sin embargo, siempre debe hacer una copia de seguridad de su base de datos antes de realizar cualquier edición de MySQL. A continuación, una vez que pueda acceder de nuevo a su sitio web, es posible que tenga que seguir nuestra guía para principiantes para la corrección de su sitio WordPress hackeado.

Dicho esto, veamos cómo añadir un usuario administrador a la base de datos de WordPress a través de MySQL.

Añadir un usuario administrador a la base de datos de WordPress con phpMyAdmin

phpMyAdmin viene preinstalado con la mayoría de las principales empresas de alojamiento de WordPress. Puede encontrarlo en la sección Bases de datos del Escritorio cPanel de su cuenta de alojamiento.

Aquí hay una captura de pantalla del panel de control de Bluehost:

Selecting phpMyAdmin on cPanel

Al hacer clic en el icono se abrirá la interfaz de phpMyAdmin. Debe seleccionar su base de datos de WordPress en la columna de la izquierda.

Después de eso, phpMyAdmin mostrará todas las tablas de su base de datos de WordPress. Va a realizar cambios en las tablas wp_users y wp_usermeta.

You Will Be Making Changes to the wp_users and wp_usermeta Tables

Añadir un usuario a la tabla wp_users

Primero, necesita encontrar la tabla wp_users y hacer clic en ella. Esto mostrará los usuarios que figuran actualmente en la tabla.

Observe en el siguiente aviso que hay dos ID de usuario en la tabla de nuestro sitio web de demostración, 1 y 2. Cuando creemos un nuevo usuario para nuestro sitio web de demostración, este ID debe ser único, por lo que escribiremos el número 3.

Debe hacer clic en la pestaña “Insertar” situada en la parte superior de la pantalla para poder insertar la información de un nuevo usuario administrador.

Click the Insert Tab

Añada la siguiente información a los campos del formulario de inserción:

  • ID: elija un número único (en nuestro ejemplo, utilizaremos 3)
  • user_login: el nombre de usuario que se utilizará al acceder al sistema
  • user_pass: añade una contraseña, y asegúrate de seleccionar MD5 en el menú de funciones (mira la captura de pantalla de abajo).
  • nombre_usuario: nombre completo o alias del usuario
  • user_email: dirección de correo electrónico del usuario
  • user_url: dirección de su sitio web
  • user_registered: seleccione la fecha y hora en que se registró el usuario mediante el calendario
  • user_activation_key: dejar en blanco
  • user_status: establecer este valor en 0
  • display_name: nombre completo o nombre para mostrar del usuario
Fill In the Fields for the New User

Una vez que haya terminado, asegúrese de hacer clic en el botón “Ir” para almacenar el nuevo usuario.

Añadir un usuario a la tabla wp_usermeta

Ahora, necesitas encontrar la tabla wp_usermeta y hacer clic en ella. Después de eso, usted debe hacer clic en la pestaña ‘Insertar’ como lo hizo en el paso anterior.

A continuación, debe añadir la siguiente información al formulario de inserción:

  • unmeta_id: déjelo en blanco (se generará automáticamente)
  • user_id: el ID de usuario que utilizó en el paso anterior
  • meta_key: debe ser wp_capabilities
  • meta_value: inserte esto: a:1:{s:13: "administrador";s:1: "1";}
Fill In the Fields for the New User

Después, cuando se desplace hacia abajo, debería encontrar campos para una segunda fila. Debe añadir la siguiente información:

  • unmeta_id: déjelo en blanco (se generará automáticamente)
  • user_id: el identificador de usuario que utilizó en los pasos anteriores.
  • meta_key: debe introducir wp_user_level
  • meta_valor: 10
Fill In the Fields for the New User

Cuando hayas terminado de introducir la información en los campos, tienes que hacer clic en el botón “Ir”. Enhorabuena, ha creado un nuevo nombre de usuario administrador.

Ahora debería poder acceder a su área de administrador de WordPress utilizando el nombre de usuario y la contraseña que especificó para este usuario.

En cuanto acceda, deberá ir a Usuarios ” Todos los usuarios y, a continuación, hacer clic en el nombre de usuario que acaba de crear.

Navigate to Users » All Users and Edit the New User

Ahora, sin cambiar nada, desplázate hasta el final de la página y haz clic en el botón “Guardar”.

Esto permitirá a WordPress limpiar el usuario que acaba de crear y añadir alguna información extra que sea necesaria.

Añadir un usuario administrador a la base de datos de WordPress mediante una consulta SQL

Si eres desarrollador, puedes acelerar el proceso utilizando código.

Sólo tienes que introducir esta consulta SQL en tu base de datos:

INSERT INTO `databasename`.`wp_users` (`ID`, `user_login`, `user_pass`, `user_nicename`, `user_email`, `user_url`, `user_registered`, `user_activation_key`, `user_status`, `display_name`) VALUES ('3', 'demo', MD5('demo'), 'Your Name', 'test@example.com', 'http://www.example.com/', '2022-09-01 00:00:00', '', '0', 'Your Name');
 
 
INSERT INTO `databasename`.`wp_usermeta` (`umeta_id`, `user_id`, `meta_key`, `meta_value`) VALUES (NULL, '3', 'wp_capabilities', 'a:1:{s:13:"administrator";s:1:"1";}');
 
 
INSERT INTO `databasename`.`wp_usermeta` (`umeta_id`, `user_id`, `meta_key`, `meta_value`) VALUES (NULL, '3', 'wp_user_level', '10');

Asegúrate de cambiar ‘databasename’ por la base de datos con la que estás trabajando.

Además, no olvides cambiar los demás valores por los que desees para el nuevo usuario, tal y como explicamos en el primer método.

Drop This SQL Query Into Your Database

Guías de expertos sobre qué hacer cuando se bloquea el acceso al administrador de WordPress

Ahora que ya sabe cómo añadir un usuario administrador a través de MySQL, puede que le interese ver algunos artículos sobre cómo corregir su sitio web cuando está bloqueado fuera del área de administración de WordPress.

Esperamos que este tutorial te haya ayudado a aprender cómo añadir un usuario administrador a la base de datos de WordPress a través de MySQL. Puede que también quieras ver nuestra guía definitiva sobre seguridad en WordPress o nuestra lista de errores comunes de WordPress y cómo corregirlos.

If you liked this article, then please subscribe to our YouTube Channel for WordPress video tutorials. You can also find us on Twitter and Facebook.

Descargo: Nuestro contenido está apoyado por los lectores. Esto significa que si hace clic en algunos de nuestros enlaces, podemos ganar una comisión. Vea cómo se financia WPBeginner , por qué es importante, y cómo puede apoyarnos. Aquí está nuestro proceso editorial .

Avatar

Editorial Staff at WPBeginner is a team of WordPress experts led by Syed Balkhi with over 16 years of experience in WordPress, Web Hosting, eCommerce, SEO, and Marketing. Started in 2009, WPBeginner is now the largest free WordPress resource site in the industry and is often referred to as the Wikipedia for WordPress.

El último kit de herramientas de WordPress

Obtenga acceso GRATUITO a nuestro kit de herramientas - una colección de productos y recursos relacionados con WordPress que todo profesional debería tener!

Reader Interactions

236 comentariosDeja una respuesta

  1. Syed Balkhi says

    Hey WPBeginner readers,
    Did you know you can win exciting prizes by commenting on WPBeginner?
    Every month, our top blog commenters will win HUGE rewards, including premium WordPress plugin licenses and cash prizes.
    You can get more details about the contest from here.
    Start sharing your thoughts below to stand a chance to win!

  2. Kris says

    I wanted to delete all spam emails registered in my site. I went to myPhpAdmin and deleted all including mine (without knowing). I searched the web ‘til I landed at this page.

    Good Job! It worked!

  3. Donato says

    Not sure where I went wrong but I get this when trying to login: You do not have sufficient permissions to access this page.

    • redhad says

      Hello Donato,

      Change the “wp_” prefix of “wp_capabilities” and “wp_user_level” to whatever prefix you have set. Example, if you changed your wordpress prefix as “mysite_” then the insert command should be:

      INSERT INTO `databasename`.`mysite_usermeta` (`umeta_id`, `user_id`, `meta_key`, `meta_value`) VALUES (NULL, ‘4’, ‘mysite_capabilities’, ‘a:1:{s:13:”administrator”;s:1:”1″;}’);

      INSERT INTO `databasename`.`mysite_usermeta` (`umeta_id`, `user_id`, `meta_key`, `meta_value`) VALUES (NULL, ‘4’, ‘mysite_user_level’, ’10’);

  4. Lou Storiale says

    Thank you for this… very easy to follow! I never would have intuitively thought I would have to add two record in the same table. Thank you again.

    WordPress add admin record… I never thought I would have gotten this done in 5 minutes.

  5. Allison Wong says

    Thank you! I love when things work! I went through the instructions as stated above and everything worked out. Just a tip – if you changed the prefix of your database tables from wp_ to something else, make sure to replace it in the code above.

  6. Houston says

    Thanks, Dasha! You’re a life saver! Was stumped until I saw I needed to also change the DB prefix for ‘wp_capabilities’ and ‘wp_user_level’!

  7. Ruben says

    Hi, thanks for the clear tips. It nearly worked – but had to change a:1:{s:13:”administrator”;s:1:”1″;} with a:1:{s:13:”administrator”;s:1:”1″;} – looks the same, just replace all the quotes (which are curly quotes) with normal quotes. Or don’t be lazy andwrite it instead of cut and paste. Otherwise the new user I created didn’t have admin access. Phew that was difficult,

  8. Reena says

    omg.. what a life saver. Just a tip you need to update the wp_capabilities meta_key value to ‘a:1:{s:13:”administrator”;b:1;}’. And for some reason it still didn’t allow me to login. So then I just typed in the new username I created and clicked on forgot password. WP sent me a password reset link and all was well.

  9. Jamie says

    I was able to gain access with the original process but now my dashboard is blank. Any ideas on what I need to do? thanks

  10. Nathan Swartz says

    As of today you also have to add another entry (and probably not the wp_user_level, not sure about that though), wp_capabilities with a value of a:1:{s:13:”administrator”;b:1;}

  11. Erik says

    You’ve got a small bug. you’ll need to update the wp_capabilities meta_key value to ‘a:1:{s:13:”administrator”;b:1;}’ for this to work correctly, otherwise great article

  12. Dasha says

    Thank you for the tutorial – very useful. However, it would be handy if there was a note that ‘wp_capabilities’ and ‘wp_user_level’ use default database prefix, i.e. ‘wp_’. If a site uses a custom DB prefix that it should be used in those strings instead.

  13. Juan says

    After finding your sollution i tweaked it a bit you can actually do everything in 2 queries without having to remember the id you create.

    Both queries have to be executed in the same action (so the same SQL input box).

    INSERT INTO `wp_users` (`ID`, `user_login`, `user_pass`, `user_nicename`, `user_email`, `user_url`, `user_registered`, `user_activation_key`, `user_status`, `display_name`)
    VALUES
    (NULL , ‘username’, MD5(‘password’), ‘User Name’, ‘email@domain.ext’, ”, NOW(), ”, ‘0’, ‘User Name’);

    INSERT INTO `wp_usermeta` (`umeta_id`, `user_id`, `meta_key`, `meta_value`)
    VALUES
    (NULL, LAST_INSERT_ID(), ‘wp_capabilities’, ‘a:1:{s:13:”administrator”;s:1:”1″;}’),
    (NULL, LAST_INSERT_ID(), ‘wp_user_level’, ’10’);

  14. Jim says

    I followed the instructions but keep getting an “invalid username” error when trying to login.
    I’ve created 3 different users but still continue getting this error.

  15. Clare says

    So glad I found this. Worked like a dream once I got the correct brackets and the right code for the version of WP that was installed

  16. Abdul Aziz says

    not working , i don’t no what mistake i have made…

    it’s showing this error

    “”” You do not have sufficient permissions to access this page. “”

    • Steve Della-Valentina says

      It seems like the latest version of WordPress has tweaked their meta keys and values to:

      dqf_capabilities -> a:1:{s:13:”administrator”;b:1;}
      dqf_user_level -> 10

      I saw the insufficient permissions prompt before noticing this, then changing the keys and values fixed it!

        • Andy says

          it’s the quotes. Curly quotes are not the same in your DB. Paste that line into your DB, then delete the quotes you pasted in and type new ones.

  17. Ginette says

    Was ok one day and then the next – lost my admin access. Thanks for this – saved me a heap of frustration. Plus I’ve learnt some sql to boot!

    Cheers!

  18. Raspal says

    Hello,

    I had a blog hosted at web host A and moved to another webhost recently. I don’t have the account with web host A any longer but have the full backup of the WP blog on my computer. I restored the backup to this new webhost B and the database as well. The blog is accessible fine. But I’m not able to login to wp-admin using any of the three admin user logins I have in the database. I checked the database from phymyadmin and all the three users are there fine.

    I also tried to change passwords of these users. I get the link to change the password, but when I try to login to wp-admin using the new password, even then I get the same WP login screen without any error shown.

    I also tried the method you gave above, to create a new user. I did as per all the steps and also tried what the commenters have suggested, but still I’m not able to login.

    I tried deleting all the tables for this blog and then again imported the database. Doing this and trying to logging in just gives a message that the database needs to be updated before I can login. So, clicking the yes, I again get the login screen and the above process repeats – getting the same WP login screen with no error.

    Note that I’m using the WP Better Security plugin and even tried deleting the plugin using FTP, but the same thing, still.

    Can you tell me what can be done in this situation and where am I going wrong? Please help.

    Thank you.

    Kind Regards,
    Raspal

    • WPBeginner Support says

      Please check your wp-config.php file make sure that it has your new database name, username, and host information. Delete .htaccess file from the root of your site. Rename plugins directory in your /wp-content/ folder. This will deactivate all your plugins. Lastly, in phpmyadmin go to wp_options table and look for homeurl and siteurl options make sure they are pointing to your domain name. Report back if none of these steps resolve your issue.

      Administrador

      • Raspal says

        Thanks for the help. I re-checked everything you mentioned above and all those things were perfect. After 2 days of fiddling, it striked me that I hadn’t tried clearing Chrome’s cache and cookies, silly me! This simple thing solved the problems which wasted my two days’ time. Sorry to have wasted your and others’ time too who read this.

        Anyway, everyone make sure to clear your cookies and cache every few days, Cookies and cache are responsible for really wierd problems. I don’t know about others but I like to keep my cookies for ages because they contain passwords to many (not-so-important but regular) sites I visit. And I take it for granted that cookies aren’t the culprit. Turned out to be wrong! Now, I have sent myself a reminder which tells me to clear the cookies and cache from all my browsers.

        Thanks again for the help. At least the options you mentioned, I will surely remember if something like this happens again. And I also learnt how to use phpmyadmin to create and even edit WP users. :) And in the process, I saw a table called lockdowns. This is created by WP Better Security plugin and I now know that I can clear this table or change the values if I am locked out of the login screen for bad logins. Thanks Syed and editorial staff!

        Kind Regards,
        Raspal

  19. Colin Steinmann says

    There is a very slight (but critical) typo in your tutorial:

    a:1:{s:13:”administrator”;s:1:”1″;} <—-this is not correct by a single character

    a:1:{s:13:"administrator";s:1:"1";} <—-this is correct, the final ″ should be a "

    The two characters look almost exactly the same, but they are slightly different.

  20. Tiago says

    Nice, it works!
    Just chanced the a:1:{s:13:”administrator”;b:1;} for the equivalent already listed in wp-capabilities and worked fine to me.

  21. Lane says

    I’ve followed all these steps, but it doesn’t appear my new user I created has been given admin role. When I log in to WordPress with the username and password I just created all I am able to see is the “Profiles” tab of the dashboard. Obviously I am missing a step along the way, but I have created two new users following this and it’s happened both time. Does anyone know what I may be doing wrong?

  22. alan says

    This don’t work tried loads of times and still cannot log in.

    (unmeta_id – leave this blank (it will be auto-generated)
    user_id – this will be the id of the user you created in the previous step. Remember we picked 4.
    meta_key – this should be wp_capabilities
    meta_value – insert this: a:1:{s:13:”administrator”;s:1:”1″;}

    Insert another row with the following information:

    unmeta_id – leave this blank (it will be auto-generated)
    user_id – this will be the id of the user you created in the previous step. Remember we picked 4.
    meta_key – this should be wp_user_level
    meta_value – 10 )
    this part is where i think i am going wrong , i can see user created but it does not log in

  23. Kristian Lander says

    a useful guide, to an issue i found of a hacker who deleted the admin alos. however upon inserting a new admin. i get the error message of INSERT command denied to user “database name” @hosting for table “wp_users”

    any ideas?

  24. Oscar Rottink says

    Maybe a weird question, but I followed the steps and can’t login. Also watched for the brackets etc.

    So I tried ‘forgot password’ and entered my e-mail which is also in the wp_users table. But it says no user is registered with that e-mail.

    Anyone a clue what I missed?

    • Oscar Rottink says

      OMG sorry. My fault. I didn’t changed the base URL in the database so my local copy (and login) were pointing at the original site. Feeling stupid.

  25. Adam says

    If you copied the code a:1:{s:13:”administrator”;b:1;} from this blog, it is possible that you got curly quotes instead of regular quotes, which will not work.

  26. Albert A. Ninyeh says

    There was a problem with the wp_capabilities valve you gave and the problem was with the quotes. the correct one is: wp_capabilities should be a:1:{s:13:”administrator”;s:1:”1″;}

    Anyone who wants to solve this problem should copy it exactly as it appears.

  27. George says

    I by accident logged in before adding the “usermeta” info. It of course read “You do not have sufficient permissions to access this page.” Even after I added the usermeta info I get the same thing.

    Any thoughts on this?

    • Editorial Staff says

      Check to see if the prefix is the same as your main database prefix. We are assuming that the user is using the default wp_ prefix. If your database prefix is something else, then it wouldn’t work.

      Administrador

      • Nat says

        I’ve tried everything and I still keep getting “You do not have sufficient permissions to access this page.” Any ideas on why this might be happening? Thanks.

      • David Abramson says

        I was getting the same error message and I think the problem comes from the check box in the second row that says “ignore”. It was checked by default for me and I got it to work once I unchecked that box.

  28. JasonC says

    Thank you so much this finally allowed me to get into my site. I tried every possible option to reset the admin password but nothing would work. I created the new account and logged in as administrator and was then able to export my work. Thanks again!

  29. Vic Dinovici says

    Hi, great article, thanks! Have a different issue though, my entire wp_users table got deleted and I don’t know how to create a wp_users table using phpMyAdmin. Can anyone help? Thanks!

    • Editorial Staff says

      Did you try repairing your database using the WordPress repair tool? Maybe that adds it back. Otherwise, you are better off reinstalling WordPress. For future, keep good backups.

      Administrador

      • Vic Dinovici says

        using the repairing DB WordPress tool won’t create the wp_users table. What I did is deleting the unused tables from the old one, lowering it’s size and uploading it again. It worked. Thanks.

  30. sibz says

    After attempting to log in it sais..

    You do not have sufficient permissions to access this page

    why did this happen?

    Thanks

      • Sibz says

        I have applied same user level as 10.
        But still does not work :(
        Can my developer have any access to my
        Cpanel if she doesnt have my ftp or cpanel
        Log in details?
        I see in phpmyadmin she is listed as admin.
        Its all so confusing especially when im new to all
        Of this!

      • Chris Cox says

        Guide is out of date. The correct string for wp_capabilities is now:

        a:1:{s:13:”administrator”;s:1:”1″;}

  31. nimbleswitch says

    I echo Ravi’s suggestion to copy the meta value from another admin. In my case “wp_capabilities” was actually databaseName-“_capabilities” and my admin level looked like this:  a:2:{s:13:”administrator”;s:1:”1″;s:17:”gform_full_access”;s:1:”1″;}
     
    Thanks for the great article. Saved my day.
     

    • Iryna says

      Copying of the wp_capabiblities-value from another admin helped me to. In my case the value was a:1:{s:13:”administrator”;s:1:”1″;}. Until this change I had recieved: “You do not have sufficient permissions to access this page.”

  32. ravidreams says

    Thanks for the useful article.
     
    a:1:{s:13:”administrator”;b:1;} didn’t work for me. I had to copy the meta value from another admin user and then it worked.

  33. michoscopic says

    For those who encounter “You do not have sufficient permissions to access this page.”, replace “wp_capabilities” with your full wordpress table name, e.g. if your usermeta tables are called wp_yourtableusermeta (as opposed to wp_usermeta in this tutorial), then you need to use wp_yourtablecapabilities instead. Same goes for wp_user_level, change it to wp_yourtableuser_level. Hope this helps.

  34. mr.minhkhang says

    In my opinion tampering with MySQL should not be on wp’beginner’, messing around with the database is simply not a beginner thing.

    I don’t know when this was posted, but the time when WordPress used MD5 has long gone. This article should be updated to use wp_hash_password instead.

  35. annedreshfield says

    Hi guys, Anne here, community manager intern at Livefyre. Welcome! Just wanted to drop in and say that everyone here loves this blog; it’s full to the brim with fantastic information. Can’t wait to read more!

    • Kosta Welissariou says

      Hi,

      I hope to get some help here. My blog was hacked with some base64 stuff. I can solve 99% of all the problems but I have 2 Admins in my wp Backend that need to be removed from mysql table before I can take other actions

      Sorry, no clue how to track the adin in the table and remove them

      WP latest
      Access to the mysql database

      tks

      Kosta

    • phil says

      If it was salted, just follow the steps, add a real email and have it send you a password reset. Boom. :) hope that helped.

Deja tu comentario

Gracias por elegir dejar un comentario. Tenga en cuenta que todos los comentarios son moderados de acuerdo con nuestros política de comentarios, y su dirección de correo electrónico NO será publicada. Por favor, NO utilice palabras clave en el campo de nombre. Tengamos una conversación personal y significativa.