LineEdit 随着输入显示textChanged (模糊搜索)

首先建立一个LineEdit在ui界面下然后给它起个名字
建立连接: 注意这里是 textChanged (也可以在ui界面下,右键点击转到槽)
searchInputEdit是搜索用的一个函数。在cpp文件下边有自己写一个

connect(ui->searchInputEdit, &QLineEdit::textChanged,this,&MainWindow::searchInputEdit);

写一个简单的数据库。并搜索数据库中的人物信息,并且在Qt的 tableView中显示。这里就省略掉。

void PatientInfoPage::searchInputEdit(){
    QStringList list;
    query->exec("select * from UserInfo");
//    //show the hint when inputting
    while(query->next()){
        list.append(query->value(2).toString()); // add all "Realname" to list
    }
    QCompleter *completer = new QCompleter(list, this);//输入框的提示
    ui->searchInputEdit->setCompleter(completer);

    if(ui->searchInputEdit->text() == NULL){
        qmode->setQuery("select Username , Realname, Status from UserInfo");
        ui->patientTableView->setModel(qmode);
    }
    else{ //这里显示模糊搜索到的人物信息。 定位的where后边 要用LIKE 和 %
        qmode->setQuery("select Username , Realname, Status from UserInfo where Realname LIKE '"+ui->searchInputEdit->text()+"%'");
        ui->patientTableView->setModel(qmode);
    }
}

这里的list变量是用来存储 模糊搜索到的人物名字。并且在输入框里简单提示。

LineEdit 随着输入显示textChanged (模糊搜索)_第1张图片

LineEdit 随着输入显示textChanged (模糊搜索)_第2张图片
数据库可以自己用想要的数据库,注意代码中的query->value(2)这个项就是用户名称哪项。所以我写的这个是按照用户名字来搜索,也可以按照年龄,学号等等。

你可能感兴趣的:(Qt5,数据库SQLite,C++)