[SOLVED] QSqlQueryModel macht Probleme bei Copy & Paste im Code mit MySQL
-
Wollte gerade deinen Link anschauen und bekomme folgende Meldung:
Notice
The following errors were encountered
There is no content to display on this link or it has restricted access. -
Das Kopieren hat nicht geklappt...
"Korrektur: ":https://qt-project.org/forums/viewthread/16417 -
Ah okay. Klingt sehr interessant was er da gepostet hat. Also die Datenbank so sauber schließen wie du es vorher gezeigt hast.
Am besten baue ich mein Programm auf eine DB um aber mit mehr Tabellen. Dann kann ich die Verbindung offen lassen in dem Fall.In dem ich folgende Funktion ausführe öffne ich ja eine Verbindung zur DB:
@bool db1Open();@
Funktion selber:
@bool Database::db1Open()
{
QSettings settings("SETTINGS");
settings.beginGroup("Einstellungen");
QString server = settings.value("Server").toString();
int port = settings.value("Port").toInt();
settings.endGroup();db1 = QSqlDatabase::addDatabase("QMYSQL"); db1.setDatabaseName("DB"); db1.setHostName(server); db1.setPort(port); db1.setUserName("NAME"); db1.setPassword("PASSWORD"); if(!db1.open()) return false; else return true;
}@
Und wenn ich Sie nicht mehr brauche dann schließen mit folgendem Code:
@QSqlDatabase::removeDatabase(data.db1.connectionName());@
-
Das Öffnen ist völlig korrekt - zum Schließen solltest du das QSQlDatabase Objekt vor dem removeDatabase noch leeren.
Sieht dann so aus:@
data.db1. = QSqlDatabase();
QSqlDatabase::removeDatabase(data.db1.connectionName());
@ -
Ah vergessen :) gleich probieren. Danke ;)
-
So sieht meine Close-Funktion aus:
@void Database::db1Close()
{
db1 = QSqlDatabase();
QSqlDatabase::removeDatabase(db1.connectionName());
}@Aber das Problem besteht immer noch :(
@Access is denied.
QSqlDatabasePrivate::addDatabase: duplicate connection name 'qt_sql_default_connection', old connection removed.
QSqlDatabasePrivate::removeDatabase: connection 'qt_sql_default_connection' is still in use, all queries will cease to work.
QSqlDatabasePrivate::addDatabase: duplicate connection name 'qt_sql_default_connection', old connection removed.
QSqlDatabasePrivate::addDatabase: duplicate connection name 'qt_sql_default_connection', old connection removed.@ -
Ich würde jetzt im Debug-Modus diese Stelle Schritt für Schritt untersuchen.
Die Meldung "Access is denied" bezieht sich wahrscheinlich auf den User? -
Jetzt hab ich mit etwas anderen einen hässlichen Fehler. Ich muss seit einem Update von Windows alle neue Projekt mit Adminrechten starten sonst geht das Programm nicht auf.
-
Meldung:
@Failed to start program. Path or permissions wrong?@
Ist aber alles richtig -
Ich lege ein ganz neues Projekt an und der Creator macht das alles richtig aber ich habe immer das kleine Wappen von Win7 wenn etwas Adminrechte braucht. Was das für ne scheiße
-
Hi Alex,
das ist sicher ein Problem mit den Einstellungen von Win7.
Google doch mal nach "Win7 Update Admin" -
Hi,
Danke hat geholfen. Nun geht es wieder. Sau blöder Fehler xD
Aber nun zurück zum Fehler das er den Inhalt vom TableView verliert ;) -
Hi,
du solltest - auch wenn's mühsam ist - im debug prüfen, was nach den Abfragen in welchem Query steht, z.B.:
@
qDebug() << qry.value(0).toString();
@Wenn das abgesichert ist, das gleiche mit den models:
@
qDebug() << model->data(model->index(0, 0)).toString();
@ -
Hallo,
hab jetzt mal ein kleines Testprogramm gemacht um vielleicht den Fehler leichter zu verstehen:
Datenbank Klasse:
@class Database
{public:
QSqlDatabase dbUser;
QSqlDatabase dbMemory;public:
Database();bool dbUserOpen(); void dbUserClose(); bool dbMemoryOpen(); void dbMemoryClose();
};@
@bool Database::dbUserOpen()
{
QSettings settings("A.B.Solution","Memory");
settings.beginGroup("Einstellungen");
QString server = settings.value("Server").toString();
int port = settings.value("Port").toInt();
settings.endGroup();dbUser = QSqlDatabase::addDatabase("QMYSQL"); dbUser.setDatabaseName("DATENBANK1"); dbUser.setHostName(server); dbUser.setPort(port); dbUser.setUserName("USER"); dbUser.setPassword("PASSWORD"); if(!dbUser.open()) return false; else return true;
}
void Database::dbUserClose()
{
dbUser = QSqlDatabase();
QSqlDatabase::removeDatabase(dbUser.connectionName());
}bool Database::dbMemoryOpen()
{
QSettings settings("A.B.Solution","Memory");
settings.beginGroup("Einstellungen");
QString server = settings.value("Server").toString();
int port = settings.value("Port").toInt();
settings.endGroup();dbMemory = QSqlDatabase::addDatabase("QMYSQL"); dbMemory.setDatabaseName("DATENBANK2"); dbMemory.setHostName(server); dbMemory.setPort(port); dbMemory.setUserName("USER"); dbMemory.setPassword("PASSWORD"); if(!dbMemory.open()) return false; else return true;
}
void Database::dbMemoryClose()
{
dbMemory = QSqlDatabase();
QSqlDatabase::removeDatabase(dbMemory.connectionName());
}@Wenn ich mich anmelde:
@Database data;
user = ui->userEdit->text();
password = ui->passwordEdit->text();
int count = 0;if(!data.dbUserOpen()) QMessageBox::information(this,"Info","Fehler beim öffnen der Datenbank.\nBitte Verbindung oder IP-Adresse überprüfen."); else { QSqlQuery *qry = new QSqlQuery(data.dbUser); qry->prepare("SELECT * FROM userList WHERE user = '"+user+"'"); if(qry->exec()) { while(qry->next()) { userDB = qry->value(1).toString(); passwordDB = qry->value(2).toString(); data.dbUserClose(); count++; } } else { QMessageBox::critical(this,"MySQL Error",qry->lastError().text()); data.dbUserClose(); this->close(); } if(userDB == user && passwordDB == password && count == 1) { Menue men; this->close(); men.setModal(true); men.exec(); } else { QMessageBox::information(this,"Info","Login fehlgeschlagen. Bitte versuchen Sie es nochmal."); ui->userEdit->setText(""); ui->passwordEdit->setText(""); } }@
Habe ich keinerlei Probleme. Speichere ich was in die andere Datenbank ab:
@Database data;
user = ui->userEdit->text();
password = ui->passwordEdit->text();
internetSite = ui->internetsiteLine->text();
tags = ui->tagsLine->text();if(!data.dbMemoryOpen()) QMessageBox::information(this,"Info","Fehler beim öffnen der Datenbank.\nBitte Verbindung oder IP-Adresse überprüfen."); else { QSqlQuery *qry = new QSqlQuery(data.dbMemory); qry->prepare("INSERT INTO internet (id,site,user,password,tags) VALUES (NULL,'"+internetSite+"','"+user+"','"+password+"','"+tags+"')"); if(qry->exec()) { data.dbMemoryClose(); ui->userEdit->setText(""); ui->passwordEdit->setText(""); ui->internetsiteLine->setText(""); ui->tagsLine->setText(""); } else { data.dbMemoryClose(); QMessageBox::critical(this,"MySQL Error",qry->lastError().text()); } }@
Kommt wieder die Meldung:
@QSqlDatabasePrivate::addDatabase: duplicate connection name 'qt_sql_default_connection', old connection removed.@
Wie kann das sein? Hab ich irgendwo nen Code stehen der Funktioniert aber diesen Fehler produziert?
Gruß
-
Hi Alex,
ich kann keinen Fehler finden...
Versuche doch noch, das Query vor dem Schließen der Datenbank zu beenden:@
if(qry->exec())
{
qry->finish();
data.dbMemoryClose();
...
}
@ -
Auch versucht aber daran liegt es auch nicht.
Hab auch folgendes beim Close versucht:@dbMemory.removeDatabase("QMYSQL");@
aber das will ich nicht. Hmmmm.... Beim Login habe ich das Problem nicht. Da bekomme ich keinerlei Meldung. Erst wenn ich eine zweite Verbindung zu einer anderen DB mache bekomme ich die Meldung.
-
Okay habe mein Code etwas angepasst und komme langsam an das Ergebnis heran:
@dbUser = QSqlDatabase::addDatabase("QMYSQL","UserConnection");@
@dbMemory = QSqlDatabase::addDatabase("QMYSQL","MemoryConnection");@Es liegt daran. Sobald ich einmal die Verbindung gemacht habe verwendet er einen Connection und der ist Standard mässig "Default" als Name.
Speichere ich jetzt zweimal in dbMemory bekomme ich die Meldung wieder. Beim erstmal speichern nach Programmstart kommt nichts da das erstmal die Verbindung erstellt wurde.Ich hoffe es ist etwas verständlich
-
Hab auch bei der Close Funktion folgendes ergänzt:
@dbMemory.connectionName().remove("MemoryConnection");@
Er behält aber immer noch die Connection offen trotz remove
-
So...Ich glaube ich hab jetzt die passende Lösung gefunden in der Klasse Database:
@if(QSqlDatabase::contains("MemoryConnection");@
ich frage erstmal ob die Verbindung mit der DB schon besteht. Wenn ja dann verwenden dies oder öffne die DB mit diesem.
Ich glaube das ist so ganz gut :-)