nativeQuery = true的作用
当语句中有 nativeQuery = true时, @Query中的sql语句可以为自己手写的原生sql,并且写的原生sql是可以执行的,例如:
@Query(value = "select u.username,u.password from t_user u where u.username = ?1 and u.password = ?2", nativeQuery = true)
List<User> findByZH(String username, String password);
当执行@Query时,会将该"select u.username,u.password from t_user u where u.username = ?1 and u.password = ?2"拷贝到数据库,并填充占位符。但是执行语句时,有一个要求就是语句中的表名(t_user)和字段名(username,password)必须为数据库中的表名和字段名,
当没有nativeQuery = true时,@Query中value值的sql语句就只能按照规范来写。否则就会报错
Error creating bean with name 'userMapper' defined in com.example.demo.dao.UserMapper defined in @EnableJpaRepositories declared on JpaRepositoriesRegistrar
规范就是:表名必须是所写的实体类名,字段名也必须是实体类中的自定义的变量名,例如:
@Query(value = "select u.userName from User u where u.userName = ?1")
List<User> findByUserName(String username);
谢谢!