使用了很多的mybatisplus导致了遇到mybatis有点忘记了。工作遇到了这样的一个错误:
Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Unknown column 'userId' in 'where clause' at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
其实很简单就是由于粗心导致的数据库字段映射不上
新发现:如果你查询语句字段与数据库不匹配那么程序不会报错!!!
这很简单,但是有一个很有意思的点,就是如果你这个语句是删除语句,那么idea会报错。
例如你要执行删除操作,但是使用的字段在数据库中不存在,通常会导致数据库报错。删除操作需要指定正确的字段来定位要删除的数据行,如果字段不存在,数据库无法执行删除操作。
相反,如果在SQL查询中使用了不存在的字段,通常不会导致数据库报错。数据库会尝试执行查询,并返回一个空结果集。这是因为数据库引擎会根据查询中存在的有效字段进行处理,而忽略无效的字段。