我正在引用此answer和this中的代码来创建带有复选框的表格视图。
我正在尝试创建一个表,该表显示了数据库中带有复选框的学生列表。
现在我已经做到了,
问题是:
如何将复选框的值保存到我的sql数据库?
如何从数据库中的值显示复选框的初始状态? (例如:选中1表示复选框,0表示未选中)
(我乐于接受任何实现上述要求的方法,因此,除以下代码外,请随时提供您的解决方案) 这是我的代码:
mysqlquerymodel.h
class MySqlQueryModel : public QSqlQueryModel
{
Q_OBJECT
public:
explicit MySqlQueryModel(QObject *parent = 0);
Qt::ItemFlags flags(const QModelIndex & index) const;
QVariant data(const QModelIndex & index, int role) const;
bool setData(const QModelIndex & index, const QVariant & value, int role);
QMap<int, Qt::CheckState> check_state_map;
};
mysqlquerymodel.cpp(忽略qdebug进行检查)
MySqlQueryModel::MySqlQueryModel(QObject *parent) : QSqlQueryModel(parent), check_state_map()
{
}
Qt::ItemFlags MySqlQueryModel::flags(const QModelIndex & index) const
{
if (!index.isValid()) {
qDebug()<<("item1");
return nullptr;
}
if (index.column() == 2){
qDebug()<<("item2");
return Qt::ItemIsEnabled | Qt::ItemIsSelectable | Qt::ItemIsUserCheckable;
}
qDebug()<<("item3");
return Qt::ItemIsEnabled | Qt::ItemIsSelectable;
}
QVariant MySqlQueryModel::data(const QModelIndex & index, int role) const
{
if (!index.isValid()){
qDebug()<<("data1");
return QVariant();
}
if(role== Qt::CheckStateRole)
{
if(index.column() == 2)
{
if (check_state_map.contains(index.row())){
qDebug()<<("data2");
return check_state_map[index.row()] == Qt::Checked ? Qt::Checked : Qt::Unchecked;
}
qDebug()<<("data3");
return Qt::Unchecked;
}
}
return QSqlQueryModel::data(index,role);//!!!!!
}
bool MySqlQueryModel::setData(const QModelIndex & index, const QVariant & value, int role)
{
if(!index.isValid()){
qDebug()<<("set1");
return false;
}
if (role == Qt::CheckStateRole && index.column() == 2)
{
qDebug()<<("set2");
check_state_map[index.row()] = (value == Qt::Checked ? Qt::Checked : Qt::Unchecked);
}
qDebug()<<("set3");
return true;
}
我正在尝试在tawindow.ui中实现它
tawindow.cpp
//load table
void TAWindow::on_loadBtn_clicked(){
conn.connOpen();
QSqlQuery* qry = new QSqlQuery(conn.mydb);
qry->prepare("select * from students");
qry->exec();
tablemodel->setQuery(*qry);
ui->tableView->setModel(tablemodel);
conn.connClose();
}
//save table and update database
void TAWindow::on_saveBtn_clicked()
{
}
谢谢。
答案 0 :(得分:0)
您可以使用ui->combobox->ischecked();
来检查是否选中了comboBox。
并使用一个变量来存储comboBox的状态。
类似的东西:
QString var;
if(ui->comboBox->isChecked())
{
var = "Checked";
}
else
{
var = "Not Checked";
}
并将 var 存储在您的数据库中。