Рейтинг:0

mysql user@% может получить доступ с локального хоста

флаг ca

Мне всегда говорили, что "%" означает все хосты, кроме localhost.

Однако я создал user4@"%" и могу подключиться к нему с локального хоста.

Скриншот

Так что теперь я немного смущен по этому поводу. Кто-нибудь может прояснить это для меня, пожалуйста?

флаг ua
Есть ли другая запись для `user4`? Или, может быть, `"%"@"%"? Переключитесь на родственный форум dba.stackexchange.com, если вы не удовлетворены сбоем сервера.
ptor avatar
флаг ca
Неа. Это единственный.
Рейтинг:2
флаг ar

Мне всегда говорили, что "%" означает все хосты, кроме localhost.

Это неправильно.

% является подстановочным знаком. Это соответствует 0 или более любых символов:

Сопоставление шаблонов SQL позволяет использовать _ для соответствия любому одиночному символу и % для соответствия произвольному количеству символов (включая нулевые символы)

Таким образом, % в поле имени хоста соответствует Любые хост, включая локальный.

ptor avatar
флаг ca
Спасибо за информацию.
флаг ua
Но я думаю, что user@host обрабатывается по-особому.
ptor avatar
флаг ca
В документации говорится, что @"localhost" обрабатывается по-разному в системах UNIX, поскольку они используют сокет UNIX в качестве протокола для локальных подключений. Однако не сказано, в чем разница. По словам моего учителя, пользователю user1@"%" нельзя разрешать локальное подключение к серверу, но мои тесты доказывают обратное.
vidarlo avatar
флаг ar
По умолчанию клиент пытается установить связь через сокет для localhost. Однако это не меняет обработки подстановочных знаков mysql. Однако ваши тесты полностью верны и соответствуют документации re. подстановочные знаки - и ваш учитель не прав.

Ответить или комментировать

Большинство людей не понимают, что склонность к познанию нового открывает путь к обучению и улучшает межличностные связи. В исследованиях Элисон, например, хотя люди могли точно вспомнить, сколько вопросов было задано в их разговорах, они не чувствовали интуитивно связи между вопросами и симпатиями. В четырех исследованиях, в которых участники сами участвовали в разговорах или читали стенограммы чужих разговоров, люди, как правило, не осознавали, что задаваемый вопрос повлияет — или повлиял — на уровень дружбы между собеседниками.