java - Hibernate 正在自动保存一个全新的实体(完整的调用堆栈)

标签 java hibernate persistent transactional

我已经问过这个问题两次了,但我是 stackoverflow 的新手,似乎我不知道此处示例代码的格式设置规则。现在我决定给出所有的电话,我希望我能解释一下情况,因为一切都太奇怪了,我找不到合适的词来形容它。首先,我将向您提供与问题有关的类的来源。我的实际问题在页面末尾。大段代码是为了以防万一,因为我不知道什么可以解释我的问题。 这是从我的 flex 应用程序获取调用的服务外观。

public class ServiceFacade implements IAuthenticationService, IProfileService, ICampaignService {
    @Autowired
    private IAuthenticationService authenticationService;

    @Autowired
    private IProfileService profileService;

    @Autowired
    private ICampaignService campaignService;

    public void login(User user) throws AuthenticationException{
        authenticationService.login(user);
    }

    @Override
    public void logout() throws AuthenticationException {
        authenticationService.logout();
    }

    @Override
    public void sendForgottenPassword(String email) {
        authenticationService.sendForgottenPassword(email);
    }

    @Override
    public Profile getProfile(Long userId) {
        return profileService.getProfile(userId);
    }

    @Override
    public Profile updateProfile(Profile profile) {
        return profileService.updateProfile(profile);
    }

    @Override
    public Collection<String> getSocialConnectionsTypes(Long userId) {
        return profileService.getSocialConnectionsTypes(userId);
    }

    @Override
    public List<Email> findDuplicateEmails(Long profileId, List<Email> emails) {
        return profileService.findDuplicateEmails(profileId, emails);
    }

    @Override
    public Campaign getCampaign(Long campaignId) {
        return campaignService.getCampaign(campaignId);
    }

    @Override
    public Campaign updateCampaign(Campaign campaign) {
        return campaignService.updateCampaign(campaign);
    }

    @Override
    public void removeCampaign(Long campaignId) {
        campaignService.removeCampaign(campaignId);
    }

    @Override
    public void setPools(Long campaignId, Collection<Pool> pools) {
        campaignService.setPools(campaignId, pools);
    }

    @Override
    public void addPool(Long campaignId, Pool pool) {
        campaignService.addPool(campaignId, pool);
    }

    @Override
    public void removePool(Long campaignId, Pool pool) {
        campaignService.removePool(campaignId, pool);
    }

    @Override
    public List<Campaign> getCampaigns() {
        return campaignService.getCampaigns();
    }

    @Override
    public void updatePool(Long campaignId, Pool pool) {
        campaignService.updatePool(campaignId, pool);
    }
}

对我的问题很重要的方法是 findDuplicateEmails 方法。

profileService 在以下类中实现:

public class ProfileService implements IProfileService {
    @Autowired
    private IProfileManager profileManager;

    @Override
    public Profile getProfile(Long userId) {
        return profileManager.getProfile(userId);
    }

    @Override
    public Profile updateProfile(Profile profile){
        profileManager.updateProfile(profile);
        return profile;
    }

    @Override
    public Collection<String> getSocialConnectionsTypes(Long userId) {
        return profileManager.getSocialConnectionsTypes(userId);
    }

    @Override
    public List<Email> findDuplicateEmails(Long profileId, List<Email> emails) {
        return profileManager.findDuplicateEmails(profileId, emails);
    }
}

同样重要的方法是findDuplicateEmails

profileManager 的实现是以下类:

public class ProfileManager implements IProfileManager {
    @Autowired
    private IProfileDao profileDao;

    @Autowired
    private ISectionManager autoCompleteManager;

    @Autowired
    private IUserSecurityService userSecurityService;
    @Transactional
    public Profile getProfile(Long userId) {
        return profileDao.getProfileByUser(userId);
    }

    @Transactional
    public void updateProfile(final Profile profile) {

        List<Major> notApprovedMajors = extractNotApprovedMajors(profile);
        List<Degree> notApprovedDegrees = extractNotApprovedDegrees(profile);
        List<School> notApprovedSchools = extractNotApprovedSchools(profile);
        List<Language> notApprovedLanguages = extractNotApprovedLanguages(profile);
        List<Position> notApprovedPositions = extractNotApprovedPositions(profile);
        List<Company> notApprovedCompanies = extractNotApprovedCompanies(profile);
        List<Country> notApprovedCountries = extractNotApprovedCountries(profile);
        List<City> notApprovedCities = extractNotApprovedCities(profile);
        List<Certificate> notApprovedCertificates = extractNotApprovedCertificates(profile);

        autoCompleteManager.updateAll(notApprovedMajors);
        autoCompleteManager.updateAll(notApprovedDegrees);
        autoCompleteManager.updateAll(notApprovedSchools);
        autoCompleteManager.updateAll(notApprovedLanguages);
        autoCompleteManager.updateAll(notApprovedPositions);
        autoCompleteManager.updateAll(notApprovedCompanies);
        autoCompleteManager.updateAll(notApprovedCountries);
        autoCompleteManager.updateAll(notApprovedCities);
        autoCompleteManager.updateAll(notApprovedCertificates);

        profileDao.updateProfile(profile);
    }

    @Override
    public List<Email> findDuplicateEmails(Long profileId, List<Email> emails) {

        Profile persistedProfile = profileDao.findById(profileId);

        if (persistedProfile.getContact() == null)
        {
            persistedProfile.setContact(new Contact());
        }

        List<Email> resultEmails = new ArrayList<Email>();

        for (int i = 0; i < emails.size(); i++) {

            if ((!userSecurityService.guaranteeUniquePrincipal(emails.get(i)) &&
                    !isPersistedInThePersistentCollection(emails.get(i), persistedProfile.getContact().getEmails())) ||
                    isDuplicateInTheCurrentCollection(emails.get(i), emails, i + 1)) {
                resultEmails.add(emails.get(i));
            }
    }

        return resultEmails;
    }

    private boolean isDuplicateInTheCurrentCollection(Email emailToCheck, List<Email> emails, int index)
    {

        for (int i = index ; i < emails.size(); i ++) {
            if (emails.get(i).getEmailAddress().equals(emailToCheck.getEmailAddress())) {
                return true;
            }
        }

        return false;
    }

    private boolean isPersistedInThePersistentCollection(Email emailToCheck, Collection<Email> emails)
    {
        if (emails == null) {
            return false;
        }
        for (Email persistedEmail : emails) {
            if (persistedEmail.getEmailAddress().equalsIgnoreCase(emailToCheck.getEmailAddress())) {
                return true;
            }
        }

        return false;
    }
}

同样重要的方法是方法findDuplicateEmails

现在,在这个简短的背景之后,这是我的问题:

我将 Hibernate 与 spring 的 HibernateTemplate 一起使用。我发现在 findDuplicateEmails 方法中,一些来自 flex 应用程序的全新实体会自动保存。这很奇怪,在调试过程中我发现,即使我在 ProfileManager 中更改方法 findDuplicateEmails,它看起来像:

 @Override
 public List<Email> findDuplicateEmails(Long profileId, List<Email> emails) {   
     Email email = new Email();
     return null;
 }

实体电子邮件会自动保存。我还发现,如果实体的标识符不是“电子邮件”,而是其他东西,例如“newEmail”或“email1”或其他东西,则没有问题,并且当且仅当我成功时,实体才会持久化执着的。这个问题只存在于这个类中,最后,这个问题只出现在电子邮件中。我的意思是,如果我有 Phone phone = new Phone(); 实体电话只会在我希望时保留。

Flex 应用程序首先检查输入的用户电子邮件是否唯一,然后在一些用户交互之后如果输入的数据有效则调用方法 updateProfile()

最佳答案

我会下载 Hibernate 源代码并开始调试,您会在 Hibernate(发生)或您的代码中发现错误,因为这是一种奇怪的行为。 这是我曾经得到的一条建议,是找到根源的最快、最有教育意义的方法。

关于java - Hibernate 正在自动保存一个全新的实体(完整的调用堆栈),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6197220/

相关文章:

java - Spring boot服务从oracle数据库返回大数据集

java - 使用 OneToMany 将对象从 JSON 保存到数据库

java - Java 中的永久集合

haskell - 从 PersistEntity/PersistField 映射到 DB 中的列名和表名的规则是什么

haskell - runDb 中的 MaybeT 和事务

java - 实时 java - 如何应用多次运行

java - 异常处理程序卡在 tomcat 上

java - Web 应用程序、离线模式和同步

java - 如何在拖放目标TransferHandler中找出拖放源组件?

java - 使用正则表达式分割字母数字字符串不起作用