两表各选两列作为键值,进行左连接,使用std::ranges及结构体,生成C++代码
下面是使用std::ranges和结构体生成左连接的C++代码示例:
#include <iostream>
#include <vector>
#include <ranges>
#include <algorithm>
struct User {
int id;
std::string name;
int age;
};
struct Order {
int user_id;
std::string product;
int quantity;
};
int main() {
std::vector<User> users = {
{1, "Alice", 25},
{2, "Bob", 30},
{3, "Charlie", 35},
{4, "David", 40},
};
std::vector<Order> orders = {
{1, "Apple", 2},
{2, "Banana", 3},
{1, "Orange", 1},
{3, "Grape", 4},
{2, "Pear", 2},
};
auto left_join = users | std::views::join(orders)
| std::views::filter([](const auto& o) { return o.user_id == 0; })
| std::views::transform([](const auto& o) { return std::make_tuple(o.user_id, o.name, o.product, o.quantity); });
for (const auto&[user_id, name, product, quantity] : left_join) {
std::cout << user_id << " " << name << " " << product << " " << quantity << std::endl;
}
return 0;
}
在上面的示例代码中,我们定义了两个结构体:User和Order,分别表示用户和订单。然后我们创建了两个vector,分别存储了用户和订单的数据。
接下来,我们使用std::ranges来对这两个vector进行左连接。我们使用std::views::join将这两个vector连接起来,然后使用std::views::filter过滤出符合条件的元素,最后使用std::views::transform将元素转换成我们需要的格式。
最后,我们使用for循环遍历左连接结果,并输出到控制台上。
总的来说,通过使用std::ranges和结构体,我们可以很方便地对两个表进行连接,生成符合要求的数据。
原文地址: https://www.cveoy.top/t/topic/vSS 著作权归作者所有。请勿转载和采集!