QTableView如何保存复选框值C ++

时间:2019-02-11 09:57:41

标签: c++ qt sqlite

我正在引用此answerthis中的代码来创建带有复选框的表格视图。

我正在尝试创建一个表,该表显示了数据库中带有复选框的学生列表。

现在我已经做到了,

问题是:

  1. 如何将复选框的值保存到我的sql数据库?

  2. 如何从数据库中的值显示复选框的初始状态? (例如:选中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()
    {

    }

谢谢。

1 个答案:

答案 0 :(得分:0)

您可以使用ui->combobox->ischecked();来检查是否选中了comboBox。

并使用一个变量来存储comboBox的状态。

类似的东西:

QString var;

if(ui->comboBox->isChecked())
{
    var = "Checked";
}
else
{
    var = "Not Checked";
}

并将 var 存储在您的数据库中。