首先建立一个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变量是用来存储 模糊搜索到的人物名字。并且在输入框里简单提示。
数据库可以自己用想要的数据库,注意代码中的query->value(2)这个项就是用户名称哪项。所以我写的这个是按照用户名字来搜索,也可以按照年龄,学号等等。