-->
These old forums are deprecated now and set to read-only. We are waiting for you on our new forums!
More modern, Discourse-based and with GitHub/Google/Twitter authentication built-in.

All times are UTC - 5 hours [ DST ]



Forum locked This topic is locked, you cannot edit posts or make further replies.  [ 1 post ] 
Author Message
 Post subject: OneToOne bidirectional: 2 SQLs
PostPosted: Wed Jan 01, 2014 2:19 pm 
Newbie

Joined: Thu Jul 27, 2006 12:55 pm
Posts: 5
Hi and happy new year!

Considering the following (and truncated for readability sake) test case :

Code:
    @Entity
    @Getter
    @Setter
    public static class A {
        @Id
        @GeneratedValue(strategy = AUTO)
        private long id;

        @OneToOne
        private B b;
    }

    @Entity
    @Getter
    @Setter
    public static class B{
        @Id
        @GeneratedValue(strategy = AUTO)
        private long id;

        @OneToOne(mappedBy = "b")
        private A a;
    }

    /**
     * Fails because OneToOne's default fetch type is eager, so even if it loads with an outer join
     * the B relationship, il implies 2 queries because inverse OneToOne in b is eager as well.
     * Removing the inverse OneToOne leads to only one SQL.
     * @throws Exception
     */
    @Test
    public void should_perform_only_one_select_in_owner() throws Exception {
        em.getTransaction().begin();
        final A a = new A();
        final B b = new B();
        a.setB(b);
        em.persist(b);
        em.persist(a);
        em.getTransaction().commit();
        em.clear();

        final SqlCounter counter = new SqlCounter();
        ds.addListener(counter);
        final A a1 = em.find(A.class, a.getId());

        assertThat(a1.getId()).isEqualTo(a.getId());
        assertThat(counter.getCount()).isEqualTo(1); //in fact there's 2 SQL!
    }


The find produces 2 SQLs and I expected only one:

Code:
Hibernate: select eagero2ote0_.id as id1_0_1_, eagero2ote0_.b_id as b_id2_0_1_, eagero2ote1_.id as id1_1_0_ from EagerO2OTest$A eagero2ote0_ left outer join EagerO2OTest$B eagero2ote1_ on eagero2ote0_.b_id=eagero2ote1_.id where eagero2ote0_.id=?
Hibernate: select eagero2ote0_.id as id1_0_1_, eagero2ote0_.b_id as b_id2_0_1_, eagero2ote1_.id as id1_1_0_ from EagerO2OTest$A eagero2ote0_ left outer join EagerO2OTest$B eagero2ote1_ on eagero2ote0_.b_id=eagero2ote1_.id where eagero2ote0_.b_id=?

It seems while loading A, B is eagerly loaded (fine, that complies the spec), but while loading B, A and B are loaded once again and I'm surprised because both instances should be included in the persistence context.

Wouldn't be possible to use the A and B instances currently loaded and thus avoiding an unneeded SQL or may be the loading process is not completed and they're not yet included in the persistence context?

Regards


Top
 Profile  
 
Display posts from previous:  Sort by  
Forum locked This topic is locked, you cannot edit posts or make further replies.  [ 1 post ] 

All times are UTC - 5 hours [ DST ]


You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum

Search for:
cron
© Copyright 2014, Red Hat Inc. All rights reserved. JBoss and Hibernate are registered trademarks and servicemarks of Red Hat, Inc.