用Java代码实现将数据库查出来的结果放在内存中,然后根据多个字段去取值
时间: 2024-03-09 10:48:01 浏览: 94
可以使用 Java 的集合类来将数据库查询结果保存在内存中,然后根据多个字段去取值。以下是一个示例代码:
```java
import java.sql.*;
import java.util.*;
public class Main {
public static void main(String[] args) {
try {
// 连接数据库
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection(
"jdbc:mysql://localhost:3306/test",
"root",
"password"
);
// 执行查询语句
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT id, name, age, gender FROM users");
// 将查询结果保存到 List 中
List<Map<String, Object>> list = new ArrayList<>();
while (rs.next()) {
Map<String, Object> map = new HashMap<>();
map.put("id", rs.getInt("id"));
map.put("name", rs.getString("name"));
map.put("age", rs.getInt("age"));
map.put("gender", rs.getString("gender"));
list.add(map);
}
// 根据多个字段取值
Map<String, Object> item = list.stream()
.filter(map -> "张三".equals(map.get("name")) && 20 == (int)map.get("age") && "男".equals(map.get("gender")))
.findFirst()
.orElse(null);
if (item != null) {
System.out.println("id: " + item.get("id"));
System.out.println("name: " + item.get("name"));
System.out.println("age: " + item.get("age"));
System.out.println("gender: " + item.get("gender"));
} else {
System.out.println("未找到匹配项");
}
// 关闭连接
rs.close();
stmt.close();
conn.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
```
在上面的示例代码中,首先连接数据库并执行查询语句,将查询结果保存到 List<Map<String, Object>> 中。然后根据多个字段去取值,这里以 name、age、gender 字段为例,在 List 中查找这三个字段都匹配的项并输出其它字段的值。注意,这里使用了 Java 8 中的 Stream API 来进行过滤和查找操作。最后关闭连接。
阅读全文