QT QComBox实现模糊查询

一、概述

在Qt中,可以通过QComboBox和QLineEdit实现模糊查询的功能。模糊查询是指根据用户输入的文本,在下拉框的选项中进行模糊匹配,并动态地显示匹配的选项。

二、基础知识

1、QCompleter

(1)QCompleter 是 Qt 框架中提供的一个用于自动补全和模糊搜索的类。QCompleter 可以与输入框(如 QLineEdit)一起使用,为用户输入的文本提供自动补全的功能。

(2)QCompleter 的主要作用是为一个模型(例如 QStringListModel 或 QStandardItemModel)提供自动补全的功能。它可以根据用户在输入框中输入的文本,动态地过滤模型中的项,并将过滤结果作为候选项显示在输入框下方的弹出窗口中。

2、QStyledItemDelegate

(1)QStyledItemDelegate 是 Qt 框架中提供的一个用于自定义绘制和编辑每个项的委托类。它可以与诸如 QListView、QTableView、QTreeView 等控件一起使用,用于自定义项的外观和编辑行为。

(2)QStyledItemDelegate 的主要作用是控制视图中每个项的绘制和编辑方式,以实现自定义的外观和交互效果。

三、UI界面搭建

四、具体实现

1、MainWindow.h文件

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QEvent>
#include <QMainWindow>

QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

    //模糊搜索
    void obscureSearch();

private:
    Ui::MainWindow *ui;
};
#endif // MAINWINDOW_H

 2、MainWindow.cpp文件

#include "mainwindow.h"

#include "ui_mainwindow.h"

#include <QCompleter>
#include <QListView>
#include <QStyledItemDelegate>

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    obscureSearch();
}

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

void MainWindow::obscureSearch()
{
    QStringList list;
    list << "RCV_01" << "RCV_02" << "RCV_03" << "RCV_04";
    ui->comboBox->addItems(list);

    QString style = QString("QListView {"
                            "font-family: \"Arial\";"
                            "font-size: 13px; "
                            "outline: 0px;}"
                            "QListView::item {"
                            "padding: 3px 0x 3px 5px;"
                            "border-width: 0px;}"
                            "QListView::item:selected {"
                            "background-color: #004EA2;}");

    QString comStyle = style + QString("QListView::item:hover {"
                                       "background-color: #E5F1FB}");


    ui->comboBox->setView(new QListView());
    ui->comboBox->setEditable(true);
    ui->comboBox->setLineEdit(ui->lineEdit);
    ui->comboBox->setMaxVisibleItems(5);
    ui->comboBox->view()->setStyleSheet(style);

    QCompleter *pCompleter = new QCompleter(list, this);
    QStyledItemDelegate *d = new QStyledItemDelegate;
    pCompleter->popup()->setItemDelegate(d);
    pCompleter->popup()->setStyleSheet(comStyle);
    pCompleter->setCaseSensitivity(Qt::CaseInsensitive);

    ui->comboBox->setCompleter(pCompleter);
    ui->lineEdit->setCompleter(pCompleter);

    ui->lineEdit->clear();
}

 五、实现效果

  • 14
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Qt 中,可以使用 QSqlQuery 类和 SQL 语句来实现模糊查询。以下是一个示例代码: ```cpp QString keyword = "apple"; QSqlQuery query; query.prepare("SELECT * FROM fruits WHERE name LIKE ?"); query.addBindValue("%" + keyword + "%"); query.exec(); while (query.next()) { QString name = query.value(0).toString(); int price = query.value(1).toInt(); qDebug() << name << price; } ``` 这个代码片段中,我们使用了 SQL 语句的 LIKE 关键字来进行模糊查询。在 LIKE 关键字后面,我们使用了 % 符号来表示匹配任意字符的通配符,这样就可以实现模糊匹配。在代码中,我们使用了 QSqlQuery 类的 prepare() 函数来准备 SQL 语句,并使用 addBindValue() 函数来绑定参数。最后,我们使用了 while 循环来遍历查询结果集。 ### 回答2: QT中的模糊查询通常使用SQL LIKE语句。Mysql数据库中,可以使用通配符%来表示任意字符出现的次数,_表示任意单个字符。下面是一个示例代码: ```cpp QString keyword = "test"; QString query = "SELECT * FROM tablename WHERE columnname LIKE '%" + keyword + "%'"; QSqlQuery result(query); while (result.next()) { // 处理查询结果 } ``` 在这个例子中,我们使用了一个QString变量`keyword`来存储模糊查询的关键字,这里使用了"test"作为示例关键字。然后,我们构建一个SQL查询语句,并将关键字嵌入其中。我们使用LIKE和%通配符将关键字包围起来,以便在查询时匹配出现在任意位置的关键字。在这个例子中,我们假设查询的表名为`tablename`,列名为`columnname`,你可以根据实际情况修改这些值。然后我们执行这个查询,并使用`QSqlQuery`对象来处理查询结果。 以上就是在QT中使用MySQL进行模糊查询的简单方法。根据你的实际需求,你还可以使用其他方法来实现更复杂的模糊查询。总之,QT和MySQL的结合使用提供了强大的工具以满足各种查询需求。 ### 回答3: Qt与MySQL结合使用时,进行模糊查询可以使用LIKE关键字。模糊查询是指根据指定的模式或条件,在数据库中搜索符合要求的数据。 在Qt中,可以使用QSqlQuery类的exec()方法执行SQL查询语句。对于模糊查询,我们可以使用以下代码示例: ```cpp QString keyword = "apple"; // 要搜索的关键字 // 创建并打开与MySQL数据库的连接 QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL"); db.setHostName("localhost"); db.setDatabaseName("mydatabase"); db.setUserName("username"); db.setPassword("password"); bool success = db.open(); if (success) { // 执行模糊查询 QSqlQuery query; QString sql = "SELECT * FROM fruits WHERE name LIKE '%" + keyword + "%'"; query.exec(sql); // 遍历并输出结果 while (query.next()) { QString name = query.value(0).toString(); // 获取第一列的值(假设为水果名称) // 输出结果 qDebug() << "水果名称:" << name; } // 关闭数据库连接 db.close(); } else { qDebug() << "数据库连接失败"; } ``` 上述代码中,我们首先创建与MySQL数据库的连接,然后使用QSqlQuery类执行SQL查询语句。在SQL语句中,我们使用LIKE关键字,并使用%作为通配符,表示任意字符的出现次数。最后,我们通过遍历查询结果,获取需要的数据。 以上就是使用Qt进行MySQL模糊查询的简单方法。当然,实际应用中还可以根据需要进行更复杂的查询条件设置,如使用AND、OR等逻辑运算符,以便更精确地获取目标数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值