sqllite w qt
-
Czy jest jakiś sposób, żeby sprawdzić czy otwarty jest prawidłowy plik bazodanowy? Bo można otworzyć cokolwiek i zarówno db.open jak i db.isValit zwracają, że wszystko ok nawet jak się otworzy binarkę. Nawet query nie wywala błędu jak dałem zapytanie sql na obrazku png. Przy db.open radośnie tworzy pusty plik, który wg biblioteki jest prawidłowym plikiem bazy danych.
if(db.open) zwraca true nawet jak otworzyłem jako bazę danych sqllite /dev/null.
-
Wow, dobre :-) Nigdy nie próbowałem otworzyć innego pliku w QSqlLite.
Trochę rad dają tu (ostatni komentarz): https://stackoverflow.com/questions/42619851/how-to-check-database-is-exist-or-not i tu (też ostatni): https://forum.qt.io/topic/97957/how-to-check-if-sqlite-database-is-valid/5
-
@sierdzio dowiedziałem się, że trzeba sprawdzić przez QMimeType plik wcześniej. Ogólnie tam są niezłe jaja. Jak otwierasz przez db.open nieistniejący plik to tworzy automatycznie nowy pusty plik długości 0 bajtów. Dopiero jak dasz jakieś query, to tworzy strukturę bazy w pliku. query.LastError().text() przy każdym błędzie wywala no query, bez informacji co się dzieje. I taka śmieszna rzecz, wszystkie przykłady korzystania z sqllite mają if(!db.open)... Tylko nikt chyba nie sprawdził czy to coś daje :)
P.S. a ile się narzucałem mięsa, zanim zauważyłem, że tworzy puste pliki radośnie.