Qt C ++类没有命名类型

时间:2015-11-28 17:43:41

标签: c++ qt class global-variables

我试图将ComboBox放入查询并将结果放入QtableView。

我的查询有效,表视图显示结果,我的组合框接收第一列元素,但是......

当我尝试在on_comboBox_pedido_currentIndexChanged上创建新查询时,我的查询结果始终为空。

我试图将我的“登录teste”声明类设为公开,并显示“'登录'未命名类型”

这是我的pedidos.h。我试过在这里创建一个公共测试人员!!!

#ifndef PEDIDOS_H
#define PEDIDOS_H

#include <QDialog>
#include <QTableView>
#include <QtWidgets>

namespace Ui {
class Pedidos;
}

class Pedidos : public QDialog
{
    Q_OBJECT

public:

    Login teste;  // not working - "does not name a type" error

    explicit Pedidos(QWidget *parent = 0);
    ~Pedidos();

private slots:
    void on_pushButton_load_pedidos_clicked();

    void on_comboBox_pedido_currentIndexChanged(const QString &arg1);

private:
    Ui::Pedidos *ui;
};

#endif // PEDIDOS_H

这是我的pedidos.cpp

#include "login.h"
#include "pedidos.h"
#include "ui_pedidos.h"

Pedidos::Pedidos(QWidget *parent) :
    QDialog(parent),
    ui(new Ui::Pedidos)
{
    ui->setupUi(this);

    Login conn;

    if(!conn.connOpen())
       ui->label_pedidos_conn->setText("Falha na conexão ao Database");
    else{
       ui->label_pedidos_conn->setText("Database Ok");
       conn.connClose();
     }

}

Pedidos::~Pedidos()
{
    delete ui;
}

void Pedidos::on_pushButton_load_pedidos_clicked()
{
    Login conn;
    QSqlQueryModel *modal=new QSqlQueryModel();

    QSqlQuery *qry=new QSqlQuery(conn.mydb);

    qry->prepare("SELECT pedido.id_pedido, usuarios.nome_user, endereco.bairro, \
                         pedido.id_user, pedido.data   FROM pedido \
                  INNER JOIN usuarios ON pedido.id_user=usuarios.id_user \
                  INNER JOIN endereco ON pedido.id_endereco=endereco.id_endereco \
                  WHERE pedido.status=0");

            qry->exec();

    qDebug() << qry->lastError().text();

    modal->setQuery(*qry);

    modal->setHeaderData(0, Qt::Horizontal, "Pedido");
    modal->setHeaderData(1, Qt::Horizontal, "Usuário");
    modal->setHeaderData(2, Qt::Horizontal, "Bairro");

    ui->tableView_pedidos->setModel(modal);

    ui->comboBox_pedido->setModel(modal);  // My ComboBox here!

    ui->tableView_pedidos->resizeRowsToContents();
    ui->tableView_pedidos->resizeColumnsToContents();

   ui->tableView_pedidos->setColumnHidden(3, true);
   ui->tableView_pedidos->setColumnHidden(4, true);

    while(qry->next()){

        QString usuario = qry->value(0).toString();
        qDebug() << "id:" << usuario;
    }

    //qDebug() << (modal->rowCount());

}

void Pedidos::on_comboBox_pedido_currentIndexChanged(const QString &arg1)
{
    QString id_pedido=ui->comboBox_pedido->currentText();
    qDebug() << id_pedido;



       QSqlQueryModel *modal2=new QSqlQueryModel();

//works until here...if uncomment any line from here nok

        Login meudb;  // this line uncommented, query on pushbutton is not working ( blank )
        //QSqlQuery *qry=new QSqlQuery(meudb.mydb);
        //meudb.connClose();


}

如果我对“登录meudb”这一行发表评论,那么查询结果就可以了。

所以我尝试创建一个全局的“Login teste”来替换我当地的“Login conn”。

我在这里阅读了很多文章。

提前致谢

1 个答案:

答案 0 :(得分:0)

在你的文件pedidos.h中试试这个:

#ifndef PEDIDOS_H
#define PEDIDOS_H

#include <QDialog>
#include <QTableView>
#include <QtWidgets>

class Login;
...