C++使用ODBC实现模糊查询

使用m_strFilter,直接上代码

pMatSet->m_strFilter = _T("");	//格式化过滤条件
CString sql;
sql.Format(_T("materialName like '%%%s%%' "), m_uiName);  //按名字查询

pMatSet->m_strFilter = sql; //设置过滤条件

说明:

materialName 是数据库表的某一个字段,给UI界面的编辑框添加变量m_uiName

代码的作用:

前提已经使用UpdateData(TRUE);把编辑区的内容更新到变量m_uiName中 ;

找到数据库表中含有m_uiName的所有行,m_uiName可以在开头、末尾或者中间的任意位置

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
C++ 中,可以使用结构体或类来表示每个数据项,然后使用 STL 中的容器(如 vector 或 map)来存储这些数据项,并使用 lambda 表达式或自定义的比较函数来实现多条件模糊查询。 例如,假设我们有一个 Person 结构体,包含 name,age 和 gender 三个属性,我们可以使用 vector 来存储多个 Person 对象,并使用 lambda 表达式来实现多条件模糊查询。示例代码如下: ```c++ #include <iostream> #include <vector> #include <algorithm> #include <string> using namespace std; struct Person { string name; int age; string gender; }; int main() { vector<Person> people = { {"Alice", 18, "Female"}, {"Bob", 25, "Male"}, {"Charlie", 30, "Male"}, {"David", 20, "Male"}, {"Emily", 22, "Female"} }; // 查询年龄大于 20,性别为 Male 的人 auto query = [](const Person& p) { return p.age > 20 && p.gender == "Male"; }; vector<Person> result; copy_if(people.begin(), people.end(), back_inserter(result), query); for (const auto& p : result) { cout << p.name << " " << p.age << " " << p.gender << endl; } return 0; } ``` 在上面的代码中,我们使用 lambda 表达式来定义查询条件 query,然后使用 std::copy_if 算法和 back_inserter 迭代器将满足条件的 Person 对象插入到 result 容器中,最后输出查询结果。 除了 lambda 表达式,我们还可以使用自定义的比较函数来实现多条件模糊查询。示例代码如下: ```c++ #include <iostream> #include <vector> #include <algorithm> #include <string> using namespace std; struct Person { string name; int age; string gender; }; bool compare(const Person& p1, const Person& p2) { if (p1.age != p2.age) { return p1.age > p2.age; } else if (p1.gender != p2.gender) { return p1.gender < p2.gender; } else { return p1.name < p2.name; } } int main() { vector<Person> people = { {"Alice", 18, "Female"}, {"Bob", 25, "Male"}, {"Charlie", 30, "Male"}, {"David", 20, "Male"}, {"Emily", 22, "Female"} }; // 按照年龄降序、性别升序、姓名升序排序 sort(people.begin(), people.end(), compare); for (const auto& p : people) { cout << p.name << " " << p.age << " " << p.gender << endl; } return 0; } ``` 在上面的代码中,我们使用自定义的 compare 函数来实现多条件模糊查询,该函数按照年龄降序、性别升序、姓名升序排序。最后,我们使用 std::sort 算法将 people 容器中的元素按照 compare 函数定义的顺序排序,并输出排序结果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值