Mysql
 sql >> डेटाबेस >  >> RDS >> Mysql

जेपीए एनोटेशन के साथ MYSQL ऑटोइनक्रिकमेंट फ़ील्ड को एनोटेट कैसे करें

एक MySQL AUTO_INCREMENT का उपयोग करने के लिए कॉलम, आपको एक IDENTITY का उपयोग करना चाहिए रणनीति:

@Id @GeneratedValue(strategy=GenerationType.IDENTITY)
private Long id;

AUTO . का उपयोग करने पर आपको यही मिलेगा MySQL के साथ:

@Id @GeneratedValue(strategy=GenerationType.AUTO)
private Long id;

जो वास्तव में

. के बराबर है
@Id @GeneratedValue
private Long id;

दूसरे शब्दों में, आपकी मैपिंग काम करनी चाहिए। लेकिन हाइबरनेट को id को छोड़ देना चाहिए SQL सम्मिलित कथन में कॉलम, और यह नहीं है। कहीं न कहीं एक तरह का बेमेल होना चाहिए।

क्या आपने अपने हाइबरनेट कॉन्फ़िगरेशन में एक MySQL बोली निर्दिष्ट की थी (शायद MySQL5InnoDBDialect या MySQL5Dialect आपके द्वारा उपयोग किए जा रहे इंजन के आधार पर)?

इसके अलावा, तालिका किसने बनाई? क्या आप संबंधित डीडीएल दिखा सकते हैं?

अनुवर्ती: मैं आपकी समस्या का पुनरुत्पादन नहीं कर सकता। आपके . के कोड का उपयोग करना इकाई और आपका डीडीएल, हाइबरनेट MySQL के साथ निम्नलिखित (अपेक्षित) SQL उत्पन्न करता है:

insert 
into
    Operator
    (active, password, username) 
values
    (?, ?, ?)

ध्यान दें कि id जैसा कि अपेक्षित था, उपरोक्त कथन से कॉलम अनुपस्थित है।

संक्षेप में, आपका कोड, तालिका परिभाषा और बोली सही और सुसंगत हैं, इसे काम करना चाहिए। यदि यह आपके लिए नहीं है, तो हो सकता है कि कुछ सिंक से बाहर हो (एक साफ निर्माण करें, बिल्ड निर्देशिका को दोबारा जांचें, आदि) या कुछ और गलत है (कुछ भी संदिग्ध के लिए लॉग जांचें)।

बोली के संबंध में, केवल MySQL5Dialect . के बीच अंतर या MySQL5InnoDBDialect क्या यह बाद में ENGINE=InnoDB adds जोड़ता है डीडीएल उत्पन्न करते समय तालिका वस्तुओं के लिए। एक या दूसरे का उपयोग करने से उत्पन्न SQL नहीं बदलता है।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. MySQL:एक सेलेक्ट स्टेटमेंट केस संवेदनशील है?

  2. GROUP_CONCAT ऑर्डर BY

  3. ASCII () उदाहरण – MySQL

  4. एलपीएडी () फ़ंक्शन MySQL में कैसे काम करता है

  5. MySQL में एक टेबल के कैरेक्टर सेट और कॉलेशन को कैसे सेट करें