JAVA List<T> 怎么传入对象
时间: 2023-12-15 12:04:21 浏览: 36
List<T> 可以通过以下方式传入对象:
1. 创建一个空的 List<T> 对象,并通过 add() 方法添加元素:
```
List<T> myList = new ArrayList<T>();
myList.add(myObject);
```
2. 使用 Arrays.asList() 方法将数组转换为 List<T> 对象:
```
T[] myArray = {object1, object2, object3};
List<T> myList = Arrays.asList(myArray);
```
3. 使用 Collections.addAll() 方法将元素添加到已有的 List<T> 对象中:
```
List<T> myList = new ArrayList<T>();
Collections.addAll(myList, object1, object2, object3);
```
4. 使用 Stream API 将元素添加到已有的 List<T> 对象中:
```
List<T> myList = new ArrayList<T>();
Stream.of(object1, object2, object3).forEach(myList::add);
```
相关问题
java实现mysql传入list<T>批量统计type字段包含指定值的个数,返回list<map>
假设你已经有了一个Java类`T`,它对应着MySQL中的一张表,其中有一个名为`type`的字段。可以按照如下步骤实现传入`List<T>`批量统计`type`字段包含指定值的个数,并返回`List<Map>`的功能:
1. 引入MySQL的JDBC驱动程序,连接到MySQL数据库。
```java
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb", "username", "password");
```
2. 构造SQL语句,使用`IN`关键字实现批量查询。
```java
StringBuilder sql = new StringBuilder("SELECT type, COUNT(*) AS count FROM mytable WHERE type IN (");
for (int i = 0; i < types.size(); i++) {
sql.append("?");
if (i < types.size() - 1) {
sql.append(",");
}
}
sql.append(") GROUP BY type");
```
其中,`types`是包含指定值的`List`,`mytable`是MySQL中对应的表名。
3. 使用`PreparedStatement`对象执行SQL语句,替换占位符参数,得到结果集。
```java
PreparedStatement ps = conn.prepareStatement(sql.toString());
for (int i = 0; i < types.size(); i++) {
ps.setString(i + 1, types.get(i));
}
ResultSet rs = ps.executeQuery();
```
4. 将结果集转换为`List<Map>`的格式。
```java
List<Map<String, Object>> result = new ArrayList<>();
while (rs.next()) {
Map<String, Object> map = new HashMap<>();
map.put("type", rs.getString("type"));
map.put("count", rs.getInt("count"));
result.add(map);
}
```
5. 关闭数据库连接,返回结果集。
```java
rs.close();
ps.close();
conn.close();
return result;
```
完整的Java代码如下:
```java
public List<Map<String, Object>> countTypes(List<T> list, List<String> types) throws ClassNotFoundException, SQLException {
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb", "username", "password");
StringBuilder sql = new StringBuilder("SELECT type, COUNT(*) AS count FROM mytable WHERE type IN (");
for (int i = 0; i < types.size(); i++) {
sql.append("?");
if (i < types.size() - 1) {
sql.append(",");
}
}
sql.append(") GROUP BY type");
PreparedStatement ps = conn.prepareStatement(sql.toString());
for (int i = 0; i < types.size(); i++) {
ps.setString(i + 1, types.get(i));
}
ResultSet rs = ps.executeQuery();
List<Map<String, Object>> result = new ArrayList<>();
while (rs.next()) {
Map<String, Object> map = new HashMap<>();
map.put("type", rs.getString("type"));
map.put("count", rs.getInt("count"));
result.add(map);
}
rs.close();
ps.close();
conn.close();
return result;
}
```
需要注意的是,这里使用了`PreparedStatement`对象来执行SQL语句,可以防止SQL注入攻击,并且提高了SQL语句的执行效率。同时,为了简化示例,这里使用了`Map`来保存每个`type`和对应的个数,实际开发中可以根据需要修改返回结果的格式。
List<UserInfo> 转换成 Map<Long,List<UserInfo>>
要将List<UserInfo>转换成Map<Long,List<UserInfo>>,可以使用foreach标签来实现。首先,在mapper层的SysUserMapper.java文件中,可以定义一个方法来实现这个转换操作。方法的参数是List<UserInfo> userList,表示要转换的列表。在方法内部,可以使用Java的foreach循环遍历列表,将每个UserInfo对象的id作为键,将对象本身添加到对应的值列表中。最后,将键值对添加到一个Map<Long,List<UserInfo>>对象中,并将其返回。
下面是一种可能的实现方式:
```java
public Map<Long, List<UserInfo>> convertListToMap(List<UserInfo> userList) {
Map<Long, List<UserInfo>> resultMap = new HashMap<>();
for (UserInfo userInfo : userList) {
Long id = userInfo.getId();
if (resultMap.containsKey(id)) {
resultMap.get(id).add(userInfo);
} else {
List<UserInfo> list = new ArrayList<>();
list.add(userInfo);
resultMap.put(id, list);
}
}
return resultMap;
}
```
这样,当调用该方法并传入List<UserInfo>对象时,将返回一个Map<Long,List<UserInfo>>对象,其中每个键是UserInfo对象的id,对应的值是具有相同id的UserInfo对象列表。
请注意,以上只是一种可能的实现方式,具体的实现方式可能因具体需求而有所不同。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [Mybatis/Ibatis框架--动态SQL, foreach标签与List<T>、数组参数案例](https://blog.csdn.net/dear_Alice_moon/article/details/87534656)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]