qsql 关联_QTableView与QSqlTableModel显示mysql数据库中的数据,怎么在QTableView的项中添加chekbox按钮与上拉列表啊真心求指导...

在QTableView中结合QSqlTableModel显示MySQL数据时,如何添加复选框和下拉列表的问题。需求是:复选框状态与数据库同步,选中状态以0或非0表示;下拉列表在复选框选中后启用,选择内容也需与数据库关联。解决方案涉及代理类和自定义模型。
摘要由CSDN通过智能技术生成

QTableView与QSqlTableModel显示mysql数据库中的数据,如何在QTableView的项中添加chekbox按钮与下拉列表啊?真心求指导。

各位大侠好,利用QTableView与QSqlTableModel显示mysql数据库中的数据,如何在QTableView的项中添加chekbox按钮与下拉列表啊?

我想在QTableView的视图中,添加checkbox按钮,如何实现啊,可以点击选中与取消,点击与取消的状态要反应到数据库中。

123928895.png

例如图片所示:QTableView视图根据数据库的行列生成,【检测内容】列中的checkbox按钮如何实现啊?选中与不选中状态可以在数据库中用0或非零表示(只是这么个意思),如果数据库中对应【检测内容】列中的项非0,则checkbox选中,为0则不选中。

123928896.png

如上图所示,在【检测内容】列为checkbox按钮,【预期规格】与【预期速率】列为下拉列表combox,默认下拉列表不使能,当选中checkbox后,下拉列表才能够使能,从中选择内容。大侠们如何实现啊?

总结一下,我想知道,QTableView中如何嵌入checkbox与combox下拉列表,checkbox与combox下拉列表选择内容能够与数据库进行关联。研究了一段时间,百思不得其解。求做个的大侠们指导,拜谢了。

对QTableView、QSqlTableModel还不是很熟悉,求指导,再次拜谢。

------解决方案--------------------

引用:各位大侠好,利用QTableView与QSqlTableModel显示mysql数据库中的数据,如何在QTableView的项中添加chekbox按钮与下拉列表啊?

我想在QTableView的视图中,添加checkbox按钮,如何实现啊,可以点击选中与取消,点击与取消的状态要反应到数据库中。

例如图片所示:QTableView视图根据数据库的行列生成,【检测内容……

哥,用代理吧……

------解决方案--------------------

参照下面的例子:

123928897.png

------解决方案--------------------

引用:引用:引用:各位大侠好,利用QTableView与QSqlTableModel显示mysql数据库中的数据,如何在QTableView的项中添加chekbox按钮与下拉列表啊?

我想在QTableView的视图中,添加checkbox按钮,如何实现啊,可以点击选中与取消,点击与取消的状态要反应到数……

Qt自带的例子有,这个我之前也折腾了个把星期,论坛提问基本无效,只能自己看例子参悟了,亲,注意参悟这个词语。。。

友情提示,请直接拷贝例子修改代码……

------解决方案--------------------

如果你的表格列是固定的就比较好实现。

你可以继承一个QSqlTableModel类,比如mySqlTableModel:public QSqlTableModel.

在mySqlTableModel中重新实现“Qt::ItemFlags flags(const QModelIndex &index) const;”函数。   这样来选择“下拉列表”的使能。

下拉列表可以用代理类来实现。我这贴一个我自己做的下拉列表的代理类,仅供拍砖。

#ifndef DELEGATE_COMBO_BOX_H

#define DELEGATE_COMBO_BOX_H

#include 

class delegate_combo_box : public QStyledItemDelegate

{

Q_OBJECT

public:

delegate_combo_box(QObject *parent = 0);

delegate_combo_box(QStringList menuList);

void paint(QPainter *painter,

const QStyleOptionViewItem &option, const QModelIndex &index) const;

QSize sizeHint ( const QStyleOptionViewItem & option, const QModelIndex & index ) const;

// Create an editor you specified.

QWidget *createEditor(QWidget *parent, const QStyleOptionViewItem &,

const QModelIndex &index) const;

//Get data of model to editor.

void setEditorData(QWidget *editor, const QModelIndex &index) const;

//Push data to model when edited.

void setModelData(QWidget *editor, QAbstractItemModel *model,

const QModelIndex &index) const;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值