List<User> userList = new insertUser<>(); 提示找不到符号
时间: 2024-09-15 16:14:50 浏览: 74
这个错误提示“找不到符号”通常是由于IDE无法识别`insertUser<>()`作为构造函数或者静态方法导致的。在MyBatis中,`List<User>` 是一个泛型类型的列表,而 `new insertUser<>()` 似乎不是正确的语法。
如果你想要创建一个新的`User`对象的列表,你应该使用`ArrayList`或者`LinkedList`等集合类的实例化方法,并且提供适当的初始化参数。例如:
```java
List<User> userList = new ArrayList<>();
userList.add(new User()); // 如果你想添加单个用户
```
如果你是指的是某个方法返回值赋给`List<User>`,那么应该是先调用该方法获取到`List<User>`对象,而不是直接构造一个。假设有个名为`insertUsers()`的函数可以返回新用户列表:
```java
List<User> userList = insertUsers();
```
如果`insertUser`是你自定义的一个方法,那么它应该是一个返回类型为`List<User>`的方法,否则这个表达式也是错误的。
相关问题
使用sql标签 实现以下方法 批量插入 int insertUsers(List<User> users) int insertUsers(@Param("users")List<User> users) 根据id来修改,当user中有值的时候就修改,当user中没有值的时候不修改 int updateSelectiveUser(@Param("user")User user) in查询 List<User> selectUserListByIds(List<Integer> ids); 根据条件查询,user成员变量有空值 List<User> selectUserListByUser(@Param("user") User user); 插入并获取主键Id(需要用到还没有讲到的selectkey) int insertUser(@Param("user") User user);
好的,以下是使用SQL标签实现以上方法的代码:
```
@Mapper
public interface UserDao {
@Insert({
"<script>",
"insert into user(name, age, gender) values ",
"<foreach item='user' index='index' collection='users' separator=','>",
"(#{user.name}, #{user.age}, #{user.gender})",
"</foreach>",
"</script>"
})
int insertUsers(@Param("users") List<User> users);
@Update({
"<script>",
"update user set",
"<if test='user.name != null'> name = #{user.name},</if>",
"<if test='user.age != null'> age = #{user.age},</if>",
"<if test='user.gender != null'> gender = #{user.gender},</if>",
"</script>"
})
int updateSelectiveUser(@Param("user") User user);
@Select({
"<script>",
"select * from user where id in ",
"<foreach item='id' index='index' collection='ids' open='(' separator=',' close=')'>",
"#{id}",
"</foreach>",
"</script>"
})
List<User> selectUserListByIds(@Param("ids") List<Integer> ids);
@Select({
"select * from user where 1=1 ",
"<if test='user.name != null'> and name=#{user.name}</if>",
"<if test='user.age != null'> and age=#{user.age}</if>",
"<if test='user.gender != null'> and gender=#{user.gender}</if>",
})
List<User> selectUserListByUser(@Param("user") User user);
@Insert({
"insert into user(name, age, gender) values (#{user.name}, #{user.age}, #{user.gender})",
})
@SelectKey(statement = "SELECT LAST_INSERT_ID()", keyProperty = "user.id", before = false, resultType = Integer.class)
int insertUser(@Param("user") User user);
}
```
希望能够帮到你!
已知数据库的内容如下所示INSERT INTO `user` VALUES (339, '王道计组'); 下列代码为什么使用http://localhost:8081/users?userId=339打印的是null @GetMapping public void queryUserDate(@RequestParam Integer userId){ QueryWrapper<User> wrapper=new QueryWrapper<>(); wrapper.eq("user_id",userId); List<User> users=userDao.selectList(wrapper); System.out.println(users); }
根据您提供的代码和数据,我们可以看到您使用了MyBatis-Plus的ORM框架,并且从前端传入了一个名为userId的参数。但是在查询时,您使用了user_id作为查询条件,这可能导致查询不到数据。您可以尝试更改代码,将查询条件改为userId,如下所示:
```
@GetMapping
public void queryUserDate(@RequestParam Integer userId){
QueryWrapper<User> wrapper=new QueryWrapper<>();
wrapper.eq("userId",userId);
List<User> users=userDao.selectList(wrapper);
System.out.println(users);
}
```
此外,您还需要注意在实体类User中,需要将userId与数据库表中的user_id字段进行映射,可以使用@TableId注解指定主键id的映射关系,如下所示:
```
public class User {
@TableId(value = "user_id", type = IdType.AUTO)
private Integer userId;
private String name;
//其他属性和方法
//...
}
```
这样,在查询时就可以正确地根据userId查询到对应的用户数据了。
阅读全文