Це справді мається на увазі як коментар до попередньої відповіді, але занадто велике, щоб вмістити коментар StackExchange.
Я теж страждав від цієї проблеми. Тому я створив нового користувача з хешем у новому стилі, і тепер користуйтеся цим новим користувачем без проблем. Ось що я зробив:
[172.16.2.222:mysql Thu Nov 7 16:16:25 2013]> use mysql;
Database changed
[172.16.2.222:mysql Thu Nov 7 16:22:23 2013]> describe user;
describe user;
+-----------------------+-----------------------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-----------------------+-----------------------------------+------+-----+---------+-------+
| Host | char(60) | NO | PRI | | |
| User | char(16) | NO | PRI | | |
| Password | char(41) | NO | | | |
Я був радий побачити, що наш стовпець пароля вже досить широкий, щоб вмістити хеші нового стилю. (Якби його було менше 41 символу, я, можливо, не мав би сміливості розширити це :-)
[172.16.2.222:mysql Thu Nov 7 16:13:10 2013]> show variables like '%pass%';
+-----------------+-------+
| Variable_name | Value |
+-----------------+-------+
| old_passwords | ON |
| report_password | |
+-----------------+-------+
2 rows in set (0.06 sec)
old_passwords
істота ON
явно проблема, тому я тимчасово змінив його:
[172.16.2.222:mysql Thu Nov 7 16:13:59 2013]> set session old_passwords = 'OFF';
Query OK, 0 rows affected (0.05 sec)
[172.16.2.222:mysql Thu Nov 7 16:14:12 2013]> show variables like '%pass%';
show variables like '%pass%';
+-----------------+-------+
| Variable_name | Value |
+-----------------+-------+
| old_passwords | OFF |
| report_password | |
+-----------------+-------+
2 rows in set (0.06 sec)
Потім я створив нового користувача:
[172.16.2.222:mysql Thu Nov 7 16:14:16 2013]> create user 'erich' IDENTIFIED BY 'SEKRIT PASSWORD';
... і подивився на новий хеш:
[172.16.2.222:mysql Thu Nov 7 16:14:26 2013]> select * from user order by User;
+-----------+--------------+-------------------------------------------+--------
| Host | User | Password | Select_
+-----------+--------------+-------------------------------------------+--------
| localhost | someguy | 3d9505dd323e53f1 | Y
| % | someotherguy | 79b3df3b004bb855 | Y
| % | erich | *D2589EF6B59146801234567897BB190123456789 | N
| % | anotheroldguy| 60577e0d77b9212b | Y
Зауважте, наскільки мій хеш більший за інші!
Тільки щоб бути охайним, я old_passwords
повернувся до OFF
. Це, мабуть, було безглуздо, оскільки я не можу подумати, чому хтось хотів би створити нових користувачів за допомогою старих паролів, але хто знає.
У всякому разі: це вирішило це для мене.