社区所有版块导航
Python
python开源   Django   Python   DjangoApp   pycharm  
DATA
docker   Elasticsearch  
aigc
aigc   chatgpt  
WEB开发
linux   MongoDB   Redis   DATABASE   NGINX   其他Web框架   web工具   zookeeper   tornado   NoSql   Bootstrap   js   peewee   Git   bottle   IE   MQ   Jquery  
机器学习
机器学习算法  
Python88.com
反馈   公告   社区推广  
产品
短视频  
印度
印度  
Py学习  »  DATABASE

qt5从mysql数据库中选择数据

Parwiz • 5 年前 • 156 次点击  

我想建立一个登录系统,我有一个MySQL数据库,我想根据我的MySQL数据库用户名和密码登录,但它不起作用。我想我的代码有问题。请检查代码。

void MainWindow::on_loginBtn_clicked()
{

    QSqlDatabase db;

    db = QSqlDatabase::addDatabase("QMYSQL", "MyConnect");
    db.setHostName("localhost");
    db.setUserName("root");
    db.setPassword("");
    db.setDatabaseName("qtregister");

    QString username = ui->loginEdit->text();
    QString password = ui->loginPassword->text();


    if(db.open()) {

        QSqlQuery query(QSqlDatabase::database("MyConnect"));

        query.prepare(QString("SELECT username and password from users where username = :username AND password = :password"));
        query.bindValue(":username", username);
        query.bindValue(":password", password);

        if(!query.exec()) {
            QMessageBox::information(this, "Failed", "Failed To Login");

        }else {
          QMessageBox::information(this, "Success", "Login Success");
        }
    }
    else {
        QMessageBox::information(this, "Not Connected", "Not Conneced Success");
    }
}
Python社区是高质量的Python/Django开发社区
本文地址:http://www.python88.com/topic/38193
 
156 次点击  
文章 [ 1 ]  |  最新文章 5 年前
Redanium
Reply   •   1 楼
Redanium    6 年前

更新

您的查询中有错误 (有时需要在Qt喜欢的另一个环境中调试查询 mysql clis 或者网上的 http://sqlfiddle.com )

SELECT username,password from users where username = :username AND password = :password

而不是

SELECT username and password from users where username = :username AND password = :password

更正的答案

void MainWindow::on_loginBtn_clicked() {

  QSqlDatabase db;

  db = QSqlDatabase::addDatabase("QMYSQL", "MyConnect");
  db.setHostName("localhost");
  db.setUserName("root");
  db.setPassword("");
  db.setDatabaseName("qtregister");

  QString username = ui - > loginEdit - > text();
  QString password = ui - > loginPassword - > text();

  if (db.open()) {

    QSqlQuery query(db);

    query.prepare(QString("SELECT username , password from users where username = :username AND password = :password"));
    query.bindValue(":username", username);
    query.bindValue(":password", password);

    if (!query.exec()) {
      QMessageBox::information(this, "Failed", "Error in executing query");

    } else {
      while (query.next()) {
        QString usernameFromDB = query.value(0).toString();
        QString passwordFromDB = query.value(1).toString();
        qDebug() << usernameFromDB << passwordFromDB;
        if (usernameFromDB == username && passwordFromDB == password)
          QMessageBox::information(this, "Success", "Login Success");
        else
          QMessageBox::information(this, "Failed", "Username or password error");
      }
    }
  } else {
    QMessageBox::information(this, "Not Connected", "Not Conneced Success");
  }
}