无法连接到QMYSQL数据库
Cannot connect to QMYSQL Database
我试图连接到我的应用程序中的QMYSQL数据库,但每次使用此代码异常"无法打开DB"被抛出。Mysql服务器正在运行,没有任何阻塞连接。我做错了什么吗?
这是我派生的类。h:
class DatabaseConnection
{
public:
DatabaseConnection(){};
virtual ~DatabaseConnection() {};
protected:
void createConnection
(const char* dbtype, const char* connection,
const char* hostname, const char* dbName, const char* username,
const char* password, int port);
void closeDb();
bool isOpen() const;
QSqlDatabase& getDb(const char* connection);
private:
QSqlDatabase db;
};
. cpp
#include "DatabaseConnection.h"
void DatabaseConnection::createConnection(const char* dbtype, const char* connection,
const char* hostname, const char* username, const char* dbName, const char* password, int port)
{
db = QSqlDatabase::addDatabase(dbtype, connection);
db.setHostName(hostname);
db.setDatabaseName(dbName);
db.setUserName(username);
db.setPassword(password);
db.setPort(port);
}
void DatabaseConnection::closeDb()
{
db.close();
}
bool DatabaseConnection::isOpen() const
{
return db.isOpen();
}
QSqlDatabase& DatabaseConnection::getDb(const char* connection)
{
return db;
}
我就是这么用的。h:
class AuthorizeUser : private DatabaseConnection
{
public:
explicit AuthorizeUser()
{
createConnection("QMYSQL", "", "", "users", "root", "root", 3306);
};
~AuthorizeUser() { closeDb(); };
....
. cpp
#include "Authorization.h"
void AuthorizeUser::checkCredentials(const QString& m_login, const QString& m_password)
{
if (!isOpen())
throw "Cannot open DB!";
getUsersQuery.exec("SELECT * FROM users");
....
- 设置一个空字符串作为主机。尝试"localhost"。
- 您正在设置"root"作为数据库名称和"users"作为用户,这听起来不对
- 您必须按照
addDatabase()
: 所描述的方式
open()
数据库。在使用连接之前,必须初始化该连接。例如,调用setDatabaseName()、setUserName()、setPassword()、setHostName()、setPort()和setConnectOptions()中的部分或全部,最后调用open()。
相关文章:
- 查询SQLite数据库中的日期
- 有没有一种方法可以创建一个带有哈希表的数据库,该哈希表具有恒定时间查找功能
- 如何在ArangoDb AQL查询中指定数据库
- 从数据库实时显示QT c++中的数据
- 使用 pqxx 将 std::vector 存储在 postgresql 中,并从数据库中检索它
- 无法在C++中建立与MySQL数据库的连接
- 将类实现到数据库程序中
- 连接 dockerized 模型和 dockerized 数据库时出现"无法 SQLConnect"错误
- C++应用程序 MySQL odbc 数据库连接错误:在引发"otl_tmpl_exception<>"实例后终止调用
- 调试编译的服务器在数据库打开时崩溃
- C++变量mysql_query到数据库
- LMDB:在有限的内存系统中打开大型数据库
- 如何在多个线程中创建 QSql数据库连接时防止名称冲突
- 以只读模式打开数据库时SQLITE_CANTOPEN错误
- 如何使用SQLite将数据库中的值导出为C / C++中的字符串或字符?
- 如何在Qt中从数据库中检索二进制数据?
- 如何从网站获取数据并将其传输到数据库?
- 在装有 CLion 的 Mac 上使用 C++ 连接到 MySQL 数据库时出现问题
- Qt5 从 MySQL 数据库中选择数据
- 无法连接到QMYSQL数据库