java - Using update queries with objectdb -


निम्न कोड:

  EntityManagerFactory emf = persistence.createEntityManagerFactory ("test.odb" ); EntityManager em = emf.createEntityManager (); em.getTransaction () शुरू ()।; बिंदु पी = नया बिंदु (0, 0); em.persist (पी); em.getTransaction () के लिए प्रतिबद्ध ()।; em.getTransaction () शुरू ()।; क्वेरी क्वेरी = em.createQuery ("UPDATE Point SET x = 1001 जहां x = 0"); Int updateCount = query.executeUpdate (); em.getTransaction () के लिए प्रतिबद्ध ()।; TypedQuery & LT; प्वाइंट & gt; Myquery = em.createQuery ("चयन पी से पॉइंट पी जहां p.x = 1001", Point.class); सूची के & lt; प्वाइंट & gt; परिणाम = myquery.getResultList (); System.out.println ("एक्स समन्वय है:" + results.get (0) .getX ()); em.close ();   

प्रिंट करता है: एक्स समन्वय है: 0 जो गलत है, क्योंकि एक्स निर्देशांक 1001 होना चाहिए

लेकिन अगर मैं कोड को बदलता हूं:

  EntityManagerFactory emf = Perseverence.createEntityManagerFactory ("test.odb"); EntityManager em = emf.createEntityManager (); em.getTransaction () शुरू ()।; बिंदु पी = नया बिंदु (0, 0); em.persist (पी); em.getTransaction () के लिए प्रतिबद्ध ()।; em.getTransaction () शुरू ()।; क्वेरी क्वेरी = em.createQuery ("UPDATE Point SET x = 1001 जहां x = 0"); Int updateCount = query.executeUpdate (); em.getTransaction () के लिए प्रतिबद्ध ()।; em.close (); Em = emf.createEntityManager (); TypedQuery & LT; प्वाइंट & gt; Myquery = em.createQuery ("चयन पी से पॉइंट पी जहां p.x = 1001", Point.class); सूची के & lt; प्वाइंट & gt; परिणाम = myquery.getResultList (); System.out.println ("एक्स समन्वय है:" + results.get (0) .getX ()); em.close ();   

परिणाम अपेक्षा के समान है:

एक्स समन्वय है: 1001

मैंने पहले कोड स्निपेट में क्या किया है?

अद्यतन क्वेरी EntityManager को बायपास करते हैं, जिसका अर्थ है कि EntityManager को वास्तविक ऑब्जेक्ट के अप-टू-डेट दृश्य नहीं हो सकता है जैसा कि ObjectDB मैनुअल में बताया गया है:

"UPDATE क्वेरी का उपयोग करते हुए डेटाबेस में इकाई ऑब्जेक्ट्स को अद्यतन करना इकाई वस्तुओं को पुनः प्राप्त करने और फिर अपडेट करने से थोड़ा अधिक कुशल हो सकता है उन्हें, लेकिन इसे सावधानी से इस्तेमाल किया जाना चाहिए क्योंकि EntityManager को बायपास करना डेटाबेस के साथ अपना सिंक्रनाइज़ेशन तोड़ सकता है.उदाहरण के लिए, EntityManager को अवगत नहीं हो सकता है कि इसकी स्थायीता संदर्भ में एक कैश्ड इकाई ऑब्जेक्ट को UPDATE क्वेरी द्वारा संशोधित किया गया है। UPDATE क्वेरी के लिए एक अलग इकाई प्रबंधक का उपयोग करने के लिए एक अच्छा अभ्यास है। "

एक अलग EntityManager का उपयोग करना ठीक उसी प्रकार है जो आपने एक नया EntityManager को बंद करने और खोलने में किया था आपका संशोधित कोड।

वैकल्पिक रूप से, यदि आप एक ही इकाई प्रबंधक का उपयोग करना चाहते हैं, तो आप (यानी, इसकी कैश), UPDATE क्वेरी चलाने और SELECT क्वेरी चलाने से पहले।

Comments

Popular posts from this blog

jsp - No mapping found for HTTP request with URI with annotation config Spring MVC and Jetty -

java - Ajax call to jsp and jsp redirecting to further jsp -

runtime error - Cannot find an overload for op_subtraction when subtracting datetime from datetime in powershell -