我有一个如下的mysql表“ countries”
| id | name | name2 | code | area | currency | language | population |
----------------------------------------------------------------------
| .. | .. | ... | ...| ....| ... | ... | ... |
此实体“ customCountry”:
@Entity
@Table(name="countries")
public class customCountry {
@Id
@Column(name = "id",table ="countries")
private Long id;
@Column(name = "code",table ="countries")
private Long code;
@Column(name = "language",table ="countries")
private String language;
//constructors + getters/setters
}
我有这个存储库:
@Repository
public interface customCountryRepository extends JpaRepository<customCountry,Long>{
List<customCountry> findAll();
}
和此服务类:
@Service
@ComponentScan(basePackages="repository")
public class countriesService {
@Autowired
customCountryRepository customcountry_repo;
public List<customCountry> loadcustomcountries()
{
List<customCountry> validcustomcountries = customcountry_repo.findAll();
System.out.println("size: "+validcustomcountries.size());
return validcustomcountries;
}
}
问题是,当我在控制器中调用此服务方法时,我发现size = 0,但是我不明白为什么,但是我认为我很好地管理了属性和列之间的映射。 谢谢
答案 0 :(得分:0)
您可以从存储库类中删除 List<customCountry> findAll();
。
由于您已经扩展了 JpaRepository<customCountry,Long>
,因此具有此方法。
当您在存储库中提供该方法而不是其实现时。 这引起了一个问题。
只需尝试将其删除。