Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [MySQL]Nieznana baza danych 'nazwa_bazy'
Forum PHP.pl > Forum > Przedszkole
mefistofeles
Po połączeniu (zdalnym) z serwerem dostaje info:
Nieznana baza danych 'nazwa_bazy'

Nazwa bazy na pewno jest ok, ale z jakiegoś powodu apache albo bardziej mysql jest żle skonf. i nie widzi jej.
Nadałem również odpowiednie uprawnienia dla użytkowników:
GRANT ALL PRIVILEGES ON *.* TO 'user'@'%' IDENTIFIED BY 'pass' WITH GRANT OPTION;

Gdy zamiast' nazwa_bazy' użyję 'mysql' (predefiniowana baza, której nie tworzyłem a istnieje) to jak gdyby się z nią łączy
(chociaż może to tylko takie wrażenie bo to chyba zastrzeżone słowo i może dlatego taki efekt),
ale tych które sam utworzyłem jak gdyby nie widzi.

Również z basha po wykonaniu:

update db set Host='162.54.10.20' where Db='nazwa_bazy';
dostaję komunikat, że 'nie ma takiej bazy' .
(tak samo update db set Host='162.54.10.20' where Db='mysql';)

Nie wiem, może trzeba użyć jakiegoś przedrostka lub jakoś dodatkowo dopisać te bazy 'gdzies' żeby były widoczne questionmark.gif

O co tu może chodzić ?
Fifi209
A jak odpowie na SHOW DATABASES ?
mefistofeles
Pokazuje wszystkie bazy!

Teraz zauważyłem, że ten komunikat pojawia się nawet jak ustawie złe hasło i użytkownika, czyli zawesze!

Dlaczego więc dostaje błąd, że nie znaleziono bazy skoro tak naprawde nie nawiazano polaczenia skoro ustawilem zle dane?

  1. $db_dane["hostname"] = "92.213.121.111"; // nasz host, najczęsciej jest to localhost
  2. $db_dane["user"] = "roost"; // nasz login do bazy
  3. $db_dane["password"] = "fsd4445dfg"; // nasze hasło do bazy
  4. $db_dane["db"] = "baza1"; // nazwa naszej bazy danych
  5.  
  6. $connection = @mysql_connect($db_dane['hostname'], $db_dane['user'], $db_dane['password']);
  7. @mysql_select_db($db_dane['db'])
  8. or die(mysql_error());


no i zwraca: Nieznana baza danych 'baza1' mimo braku połączenia z bazą.
Jak można uzyskać prawdziwe informace co jest problemem połączenia ?
gothye
dodaj jeszcze :

  1. $connection = @mysql_connect($db_dane['hostname'], $db_dane['user'], $db_dane['password']) or die(mysql_error());


a potem :

  1. @mysql_select_db($db_dane['db'],$connection)


mefistofeles
UPDATE mysql.user
SET password=OLD_PASSWORD('somepassword')
WHERE user='someuser'
AND host='somehost';

flush privileges;

I o dziwo działa smile.gif))
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.