关于QDataWidgetMapper

本文介绍如何在Qt中使用QDataWidgetMapper组件来关联窗体中的可编辑控件与QSqlTableModel,实现了数据库记录的高效管理和更新。文章详细说明了配置过程中的三个主要步骤,并分享了一个由于多余代码导致的问题及解决办法。

今天继续改进师兄的程序,使用QDataWidgetMapper,主要是实现窗体中可以编辑的窗口和QSqlTableModel的关联。

主要有3个步骤:

1、创建 QDataWidgetMapper 对象
2、关联 model
3、关联 widgets,并创建其与model中section的映射

但是在使用的时候总是有问题,最后发现是多了一句。

部分代码如下:

addmodel=new QSqlTableModel(this);
addmodel->setTable(tr("cankao"));
//addmodel->setSort(Database_ID, Qt::AscendingOrder);
//addmodel->setEditStrategy(QSqlTableModel::OnManualSubmit);//多的那一句,耽误了我好久的时间
addmodel->select();

//1.创建 QDataWidgetMapper 对象

mapper = new QDataWidgetMapper(this);
mapper->setSubmitPolicy(QDataWidgetMapper::AutoSubmit);

//2.关联 model
mapper->setModel(addmodel);

//3、关联 widgets,并创建其与model中section的映射

mapper->addMapping(ui->le_name, Database_Name);
mapper->addMapping(ui->le_kind, Database_Kind);
mapper->addMapping(ui->le_nd, Database_Nd);
mapper->addMapping(ui->le_wd, Database_Wd);
mapper->addMapping(ui->le_sd, Database_Sd);
mapper->addMapping(ui->le_ls, Database_Ls);
mapper->addMapping(ui->le_sj, Database_Time);
mapper->addMapping(ui->le_cbm, Database_Cbm);

 

另外,参照《C++ GUI Qt4编程》重写了done

void ADDRECORD::done(int result)
{
  //将在窗体进行的更改返回给模型
  bool ok3;
  ok3=mapper->submit();//Submits all changes from the mapped widgets to the model.
  if(!ok3)
  {
  addmodel->database().rollback();//database().rollback(); //回滚
  QMessageBox::warning(this,tr("tableModel"),
      tr("数据库错误:%1").arg(addmodel->lastError().text()));
  }
  //关闭对话框,并设置返回result。

  QDialog::done(result);

}

 

 

 

 

 

给数据库添加一条记录的代码

void ADDRECORD::on_pb_tj_clicked()
{

  int row = mapper->currentIndex();//重新找回当前行
  mapper->submit();
  bool ok;
  ok=addmodel->insertRow(row);//插入行
  mapper->setCurrentIndex(row);
  ui->le_name->setFocus();

}

转载于:https://www.cnblogs.com/xufenghfut/archive/2012/09/12/2682512.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值