使用QT C 为Sevaral表单创建常见的数据库连接
Creating common database connection for sevaral forms using qt c++
我正在创建一个简单的QT应用程序,以提供详细信息并登录应用程序并从数据库中检索详细信息。它主要具有2个表单(mainwindow and Dialog和对话框)DBConncetion类已写入获得数据库连接!我使用DBConnection类通过MainWindow表格提供详细信息来登录应用程序!但是我不知道如何保持我以mainwindow表单打开的连接,并使用它将数据重新授予对话框形式的表观视图。
mycode如下
dbConnection.h (成功工作)
public:
QSqlDatabase mydb;
bool connOpen(QString uname,QString pword,QString ip,int port,QString dbname){
mydb=QSqlDatabase::addDatabase("QOCI","MyDB");
mydb.setUserName(uname);
mydb.setPassword(pword);
mydb.setHostName(ip);
mydb.setPort(port);
mydb.setDatabaseName(dbname);
mydb.open();
return true;
}
mainwindow.cpp (成功工作)
void MainWindow::on_pushButton_clicked()
{
DBconnection con;
if(con.connOpen(ui->lineEdit->text(),ui->lineEdit_2->text(),ui->lineEdit_3->text(),ui->lineEdit_4->text().toInt(),ui->lineEdit_5->text())){
Dialog dialog1;
dialog1.setModal(true);
dialog1.exec();
}
}
dialog.cpp (不工作)
void Dialog::on_pushButton_clicked()
{
QSqlQueryModel *modal = new QSqlQueryModel();
con.connOpen();
QSqlQuery* qry=new QSqlQuery(con.mydb);
qry->prepare("select NAME FROM TEST1");
qry->exec();
modal->setQuery(*qry);
ui->tableView->setModel(modal);
}
如何调整我的代码,以便可以从MainWindow表单中的连接中将数据检索到对话框中的TableWidget?
您可以传递对对话框的连接的引用,也可以使连接静态/全局。
例如1
class Dialog()
{
DBconnection &con;
Dialog(DBconnection &con) : con(con) {};
};
而不是参考,您可能还需要使用std::shared_ptr
。
通过服务定位器模式,建立连接全局/静态的一种很好的方法。该模式使用称为"服务定位器"的中央注册表,该注册表应要求返回执行某个任务所需的信息。
您可能还想研究与"依赖注入"有关的事物
相关文章:
- 如何创建一个CMake变量,除非显式重写,否则使用默认值
- 使用std::multimap迭代器创建std::list
- 在全局变量中保存类的实例以重新创建类(创建"backup")
- 使用CMake创建QML插件
- 如何在c++中为模板函数实例创建快捷方式
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 创建一个函数以在输入为负数或零时输出字符串.第一次执行用户定义的函数
- OpenCV EqualizeHist()从彩色图像创建黑白图像
- 试图在visual studio上用C++创建一个桌面应用程序
- std::threads可以从Windows DLL中的全局变量创建/销毁吗?
- 如何在C++20中创建模板别名的推导指南
- 如何为模板化对象创建模板向量?VS正在投掷C3203
- 如何创建一个空的全局类并在启动时实例化它
- 无法创建抽象类的实例
- 链接到自行创建的dll失败
- 为什么我不能在不创建字符串变量的情况下使用函数的字符串输出
- 有没有一种方法可以创建一个带有哈希表的数据库,该哈希表具有恒定时间查找功能
- 如何在C++类内存结构中创建"spacer"?
- 终端不会为C++文件创建.exe文件吗
- 使用QT C 为Sevaral表单创建常见的数据库连接