MySQL: Check if the user exists and drop it

前端 未结 14 1684
遇见更好的自我
遇见更好的自我 2020-12-02 16:43

There’s not standard way to check if a MySQL user exists and based on that drop it. Are there any workarounds for this?

Edit: I need a straight way to run this wi

相关标签:
14条回答
  • 2020-12-02 16:46

    To phyzome's answer (most highly voted one), it seems to me that if you put "identified by" at the end of the grant statement, the user will be created automatically. But if you don't, the user is not created. The following code works for me,

    GRANT USAGE ON *.* TO 'username'@'localhost' IDENTIFIED BY 'password';
    DROP USER 'username'@'localhost';
    

    Hope this helps.

    0 讨论(0)
  • 2020-12-02 16:47

    Combining phyzome's answer (which didn't work right away for me) with andreb's comment (which explains why it didn't) I ended up with this seemingly working code that temporarily disables NO_AUTO_CREATE_USER mode if it is active:

    set @mode = @@SESSION.sql_mode;
    set session sql_mode = replace(replace(@mode, 'NO_AUTO_CREATE_USER', ''), ',,', ',');
    grant usage on *.* to 'myuser'@'%';
    set session sql_mode = @mode;
    drop user 'myuser'@'%';
    
    0 讨论(0)
  • 2020-12-02 16:48
    DROP USER 'user'@'localhost';
    

    The above command will drop the user from the database, however, it is Important to know if the same user is already using the database, that session will not end until the user closes that session. It is important to note that dropped user will STILL access the database and perform any operations. DROPPING THE USER DOES NOT DROP THE CURRENT USER SESSION

    0 讨论(0)
  • 2020-12-02 16:48

    In case you have a school server where the pupils worked a lot. You can just clean up the mess by:

    delete from user where User != 'root' and User != 'admin';
    delete from db where User != 'root' and User != 'admin';
    
    delete from tables_priv;
    delete from columns_priv;
    
    flush privileges;
    
    0 讨论(0)
  • 2020-12-02 16:48

    If you mean you want to delete a drop from a table if it exists, you can use the DELETE command, for example:

     DELETE FROM users WHERE user_login = 'foobar'
    

    If no rows match, it's not an error.

    0 讨论(0)
  • 2020-12-02 16:50

    Update: As of MySQL 5.7 you can use DROP USER IF EXISTS statement. Ref: https://dev.mysql.com/doc/refman/5.7/en/drop-user.html

    Syntax: DROP USER [IF EXISTS] user [, user] ...

    Example: DROP USER IF EXISTS 'jeffrey'@'localhost';

    FYI (and for older version of MySQL), this is a better solution...!!!

    The following SP will help you to remove user 'tempuser'@'%' by executing CALL DropUserIfExistsAdvanced('tempuser', '%');

    If you want to remove all users named 'tempuser' (say 'tempuser'@'%', 'tempuser'@'localhost' and 'tempuser'@'192.168.1.101') execute SP like CALL DropUserIfExistsAdvanced('tempuser', NULL); This will delete all users named tempuser!!! seriously...

    Now please have a look on mentioned SP DropUserIfExistsAdvanced:

    DELIMITER $$
    
    DROP PROCEDURE IF EXISTS `DropUserIfExistsAdvanced`$$
    
    CREATE DEFINER=`root`@`localhost` PROCEDURE `DropUserIfExistsAdvanced`(
        MyUserName VARCHAR(100)
        , MyHostName VARCHAR(100)
    )
    BEGIN
    DECLARE pDone INT DEFAULT 0;
    DECLARE mUser VARCHAR(100);
    DECLARE mHost VARCHAR(100);
    DECLARE recUserCursor CURSOR FOR
        SELECT `User`, `Host` FROM `mysql`.`user` WHERE `User` = MyUserName;
    DECLARE CONTINUE HANDLER FOR NOT FOUND SET pDone = 1;
    
    IF (MyHostName IS NOT NULL) THEN
        -- 'username'@'hostname' exists
        IF (EXISTS(SELECT NULL FROM `mysql`.`user` WHERE `User` = MyUserName AND `Host` = MyHostName)) THEN
            SET @SQL = (SELECT mResult FROM (SELECT GROUP_CONCAT("DROP USER ", "'", MyUserName, "'@'", MyHostName, "'") AS mResult) AS Q LIMIT 1);
            PREPARE STMT FROM @SQL;
            EXECUTE STMT;
            DEALLOCATE PREPARE STMT;
        END IF;
    ELSE
        -- check whether MyUserName exists (MyUserName@'%' , MyUserName@'localhost' etc)
        OPEN recUserCursor;
        REPEAT
            FETCH recUserCursor INTO mUser, mHost;
            IF NOT pDone THEN
                SET @SQL = (SELECT mResult FROM (SELECT GROUP_CONCAT("DROP USER ", "'", mUser, "'@'", mHost, "'") AS mResult) AS Q LIMIT 1);
                PREPARE STMT FROM @SQL;
                EXECUTE STMT;
                DEALLOCATE PREPARE STMT;
            END IF;
        UNTIL pDone END REPEAT;
    END IF;
    FLUSH PRIVILEGES;
    END$$
    
    DELIMITER ;
    

    Usage:

    CALL DropUserIfExistsAdvanced('tempuser', '%'); to remove user 'tempuser'@'%'

    CALL DropUserIfExistsAdvanced('tempuser', '192.168.1.101'); to remove user 'tempuser'@'192.168.1.101'

    CALL DropUserIfExistsAdvanced('tempuser', NULL); to remove all users named 'tempuser' (eg., say 'tempuser'@'%', 'tempuser'@'localhost' and 'tempuser'@'192.168.1.101')

    0 讨论(0)
提交回复
热议问题