Я пытаюсь обновить столбец в таблице с именем PartnerPIDInfo,
со следующим фрагментом кода:
private HashMap<String, String> insertPartnerPIDInfoEntries(String
partnerId, String environment, List<PartnerPidEntity> partnerPidInfoEntries,
String user) {
HashMap<String, String> resultMap = new HashMap<>();
for (PartnerPidEntity partnerPidInfoEntry : partnerPidInfoEntries) {
logger.info("PartnerPidEntity entry:{}", partnerPidInfoEntry);
//String key = partnerPidInfoEntry.getPartnerId() +"|"+
partnerPidInfoEntry.getPID();
partnerPidInfoEntry.setPartnerId(partnerId);
String key = partnerPidInfoEntry.getPartnerId()+"|"+
partnerPidInfoEntry.getBannerOMSPid();
logger.info("PartnerPidEntity Key:" + key);
try {
partnerPidInfoEntry.fillDefaultField();
omsdbReadWriteWrapper.insertPartnerPidInfoEntry(environment,
partnerPidInfoEntry);
resultMap.put(key,"Success");
} catch (Exception e) {
logger.error("Exception writing into PartnerPidEntity:" +
e.getMessage());
resultMap.put(key,"Failed");
}
}
return resultMap;
}
Класс PartnerPidEntity:
@Entity
@Table(name = "dbo.PartnerPIDInfo", schema = "", catalog = "Coupons")
public class PartnerPidEntity implements Serializable{
private static final long serialVersionUID = 1L;
private String partnerId;
private Integer bannerPid;
private Timestamp createDate;
private Boolean isActive;
@Id
@Column(name = "PartnerId", nullable = false, length = 64)
public String getPartnerId() {
return partnerId;
}
public void setPartnerId(String partnerId) {
partnerId = partnerId;
}
@Id
@Column(name = "PID", nullable = false, length = 20)
public Integer getBannerOMSPid() {
return bannerPid;
}
public void setBannerOMSPid(Integer bannerPid) {
this.bannerPid = bannerPid;
}
@Basic
@Column(name = "CreateDate", nullable = false, length = 20)
public java.sql.Timestamp getCreateDate() {
return createDate;
}
public void setCreateDate(java.sql.Timestamp createDate) {
this.createDate = createDate;
}
@Basic
@Column(name = "IsActive", nullable = false, length = 10)
public Boolean getIsActive() {
return isActive;
}
public void setIsActive(Boolean isActive) {
this.isActive = isActive;
}
public PartnerPidEntity fillDefaultField(){
this.createDate = new java.sql.Timestamp(System.currentTimeMillis());
return this;
}
}
В строке partnerPidInfoRepo.save (partnerPIDInfoEntity);
Я получаю класс не должен быть нулевым исключением.
Также добавляем схему таблицы PartnerPidInfo:
TABLE "PartnerPIDInfo" (
"PartnerId" VARCHAR(64) NOT NULL,
"PID" INT NOT NULL,
"CreateDate" DATETIME NOT NULL,
"IsActive" BIT NOT NULL,
PRIMARY KEY ("PartnerId", "PID")
)
Журнал исключений:
PartnerPidInfo:
[com.test.jaservice.entity.PartnerPidEntity@3f7bf0eb]
[INFO] 29 08 2018 01:35:01:424[PDT]
com.test.jaservice.service.partnermanagement.ModifyPartnerServiceImpl
modifyPartnerDetailes - PartnerPidInfo:
[com.quotient.jaservice.entity.PartnerPidEntity@3f7bf0eb]
[INFO] 29 08 2018 01:35:01:425[PDT]
com.test.jaservice.service.partnermanagement.ModifyPartnerServiceImpl
insertPartnerPIDInfoEntries - PartnerPidInfo
entry:com.test.jarvisservice.entity.PartnerPidEntity@3f7bf0eb
[INFO] 29 08 2018 01:35:01:425[PDT]
com.test.jaservice.service.partnermanagement.ModifyPartnerServiceImpl
insertPartnerPIDInfoEntries - PartnerPidInfo Key:2ae444f9-b0c6-4714-bfba-
6120b8a8c6d9|24081
[INFO] 29 08 2018 01:35:01:426[PDT]
com.test.jaservice.relational.dao.core.DataSourceAspect beforeOMSDB -
DataSourceAspect invoked
[INFO] 29 08 2018 01:35:01:427[PDT]
com.test.jaservice.relational.dao.core.DataSourceAspect setDaoContext -
Environment : DEV
[INFO] 29 08 2018 01:35:01:438[PDT]
com.test.jaservice.relational.dao.core.ReadWriteAspect before -
ReadWrite Aspect invoked
[INFO] 29 08 2018 01:35:01:440[PDT]
com.test.jaservice.relational.dao.core.ReadWriteAspect before - Setting
read and write access to mariaDB
[INFO] 29 08 2018 01:35:01:440[PDT]
[INFO] 29 08 2018 01:35:01:441[PDT]
com.test.jaservice.relational.dao.core.DataSourceRouter
determineCurrentLookupKey - Read write Environment name: OMSDBDEVW
[ERROR] 29 08 2018 01:35:01:827[PDT]
com.test.jaservice.service.partnermanagement.ModifyPartnerServiceImpl
insertPartnerPIDInfoEntries - Exception writing into PartnerPidInfo:Class
must not be null; nested exception is java.lang.IllegalArgumentException:
Class must not be null
[INFO] 29 08 2018 01:35:01:838[PDT]
com.test.jaservice.rest.controllers.partnermanagement.
ModifyPartnerController modifyPartnerDetailsPOST - Modify Partner was
Successfull : {2ae444f9-b0c6-4714-bfba-6120b8a8c6d9|24081=Failed}
PartnerPIDEntity
public interface PartnerPIDInfoRepo extends
BaseRepository<PartnerPidEntity,String> {
@Transactional(readOnly = true, propagation= Propagation.REQUIRED)
@Query(value="select * from dbo.PartnerPIDInfo where PartnerId = ?
1",nativeQuery=true)
List<PartnerPidEntity> findAllPartnerPidInfoEntriesByPartnerId(String
partnerId);
}
OMSDBReadWriteWrapper:
@Service
public class OMSDBReadWriteWrapper {
@Autowired
private PartnerPIDInfoRepo partnerPidInfoRepo;
public List<PartnerPidInfo> getPartnerPIDInfoEntries(String environment,
String partnerId){
List<PartnerPidEntity> partnerPIDInfoEntities =
partnerPidInfoRepo.findAllPartnerPidInfoEntriesByPartnerId(partnerId);
return mapPartnerPIDInfoEntity(partnerPIDInfoEntities);
}
public void insertPartnerPidInfoEntry(String environment, PartnerPidEntity
partnerPIDInfoEntity){
partnerPidInfoRepo.save(partnerPIDInfoEntity);
}
}
Пожалуйста, помогите мне решить эту проблему.
Спасибо