Я новичок в Spring Data JDBC, и я изо всех сил пытаюсь создать простой Dto и сохранить его на БД.
Я использую Spring-Boot 2.1.1.RELEASE и Oracle 12 Database.
UserDto
@Table(value="USERS_T")
public class UserDto extends PersistableDto {
@Id
@Column(value="USR_USERNAME")
private String userName;
@Column(value="USR_FIRSTNAME")
private String firstName;
@Column(value="USR_LASTNAME")
private String lastName;
.....
}
UserDao
@Repository
public interface UserDao extends CrudRepository<UserDto, String> {
@Query("SELECT * FROM USERS_T u WHERE u.USR_USERNAME = :userName")
UserDto findByUserName(@Param("userName") String userName);
}
, и я просто пытаюсь сохранить его на БДвот так
public String createUser() {
UserDto userDto = new UserDto().setUserName("mapss@sapot.wrong.email.pt").setPassword("superpass").setUserType("Guest").setActive(true);
logger.info(String.format("Creating user: " + userDto));
userDto.setNew(true);
UserDto persistedUser = userDao.save(userDto);
logger.info(String.format("Persisted user: " + persistedUser));
return "Ending of create user operation";
}
Я получаю это исключение.
org.springframework.dao.DataRetrievalFailureException: The generated key is not of a supported numeric type. Unable to cast [oracle.sql.ROWID] to [java.lang.Number]
at org.springframework.jdbc.support.GeneratedKeyHolder.getKey(GeneratedKeyHolder.java:79) ~[spring-jdbc-5.1.3.RELEASE.jar:5.1.3.RELEASE]
at org.springframework.data.jdbc.core.DefaultDataAccessStrategy.getIdFromHolder(DefaultDataAccessStrategy.java:323) ~[spring-data-jdbc-1.0.3.RELEASE.jar:1.0.3.RELEASE]
Я считаю, что это как-то связано с тем фактом, что @Id является строкой.
Может ли кто-нибудь помочь мне понять, что я делаю не так?Почему это поведение?По спецификации не вижу и ограничения по типу Id.Это проблема интеграции с Oracle?Как я могу это исправить?
спасибо всем за помощь.