खोज…


पैरामीटर

टिप्पणी विवरण
@Id फ़ील्ड / कॉलम को इकाई की कुंजी के रूप में चिह्नित करता है
@Basic मार्क्स ने फ़ील्ड को एक मूल प्रकार के रूप में मैप करने का अनुरोध किया। यह आदिम प्रकार और उनके रैपर, String , Date और Calendar । एनोटेशन वास्तव में वैकल्पिक है यदि कोई पैरामीटर नहीं दिया गया है, लेकिन अच्छी शैली आपके इरादों को स्पष्ट करने के लिए निर्देशित करेगी।
@Transient क्षणिक के रूप में चिह्नित क्षेत्रों को दृढ़ता के लिए नहीं माना जाता है, बहुत सीरियलाइजेशन के लिए transient कीवर्ड की तरह।

टिप्पणियों

हमेशा एक डिफॉल्ट कंस्ट्रक्टर की जरूरत होती है, वह है, पैरामीटरलेस। मूल उदाहरण में, कोई निर्माता निर्दिष्ट नहीं था, इसलिए जावा ने एक जोड़ा; लेकिन यदि आप तर्कों के साथ एक कंस्ट्रक्टर जोड़ते हैं, तो पैरामीटर रहित कंस्ट्रक्टर को भी जोड़ना सुनिश्चित करें।

एक बहुत ही साधारण इकाई

@Entity
class Note {
    @Id
    Integer id;
 
    @Basic
    String note;

    @Basic
    int count;
}

गेटवे, सेटर आदि को संक्षिप्तता के लिए ommitted किया जाता है, लेकिन उन्हें वैसे भी JPA की आवश्यकता नहीं है।

यह जावा क्लास निम्न तालिका के लिए मैप करेगा (आपके डेटाबेस पर निर्भर करता है, यहां एक संभावित पोस्टग्रैप मैपिंग में दिया गया है):

CREATE TABLE Note (
  id integer NOT NULL,
  note text,
  count integer NOT NULL
)

JPA प्रदाताओं का उपयोग DDL उत्पन्न करने के लिए किया जा सकता है, और संभवतः यहाँ दिखाए गए से अलग DDL का उत्पादन करेगा, लेकिन जब तक प्रकार संगत हैं, तब तक रनटाइम पर समस्याएँ नहीं आएंगी। डीडीएल के ऑटो-पीढ़ी पर भरोसा नहीं करना सबसे अच्छा है।

मैपिंग से ओमिटिंग फील्ड

@Entity
class Note {
    @Id
    Integer id;
 
    @Basic
    String note;

    @Transient
    String parsedNote;

    String readParsedNote() {
        if (parsedNote == null) { /* initialize from note */ }
        return parsedNote;
    }
}

यदि आपकी कक्षा को ऐसे फ़ील्ड की आवश्यकता है जो डेटाबेस में नहीं लिखे जाने चाहिए, तो उन्हें @Transient रूप में चिह्नित करें। डेटाबेस से पढ़ने के बाद, क्षेत्र null हो जाएगा।

मानचित्रण समय और दिनांक

जावा में समय और तिथि कई अलग-अलग प्रकारों में आती है: अब ऐतिहासिक Date और Calendar , और हाल ही में LocalDate और LocalDateTime । और Timestamp , Instant , ZonedLocalDateTime और जोडा-टाइम प्रकार। डेटाबेस की ओर, हमारे पास time , date और timestamp (समय और दिनांक दोनों), संभवतः समय क्षेत्र के साथ या बिना।

जावा 8 से पहले की तारीख और समय

पूर्व जावा -8 प्रकार java.util.Date , java.util.Calendar और java.sql.Timestamp लिए डिफ़ॉल्ट मैपिंग SQL में timestamp है; java.sql.Date यह date

@Entity
class Times {
    @Id
    private Integer id;

    @Basic
    private Timestamp timestamp;

    @Basic
    private java.sql.Date sqldate;

    @Basic
    private java.util.Date utildate;

    @Basic
    private Calendar calendar;
}

यह पूरी तरह से निम्न तालिका में मैप करेगा:

CREATE TABLE times (
    id integer not null,
    timestamp timestamp,
    sqldate date,
    utildate timestamp,
    calendar timestamp
)

यह इरादा नहीं हो सकता है। उदाहरण के लिए, अक्सर एक जावा Date या Calendar का उपयोग केवल तारीख (जन्म तिथि के लिए) का प्रतिनिधित्व करने के लिए किया जाता है। डिफ़ॉल्ट मैपिंग को बदलने के लिए, या केवल मैपिंग को स्पष्ट करने के लिए, आप @Temporal एनोटेशन का उपयोग कर सकते हैं।

@Entity
class Times {
    @Id
    private Integer id;

    @Temporal(TemporalType.TIME)
    private Date date;

    @Temporal(TemporalType.DATE)
    private Calendar calendar;
}

समकक्ष SQL तालिका है:

CREATE TABLE times (
    id integer not null,
    date time,
    calendar date
)

नोट 1: @Temporal साथ निर्दिष्ट प्रकार DDL पीढ़ी को प्रभावित करता है; लेकिन आप सिर्फ Date @Basic एनोटेशन के साथ Date करने के लिए date प्रकार का नक्शा नक्शा भी कर सकते हैं।

नोट 2: Calendar केवल time नहीं बना रह time

जावा 8 के साथ दिनांक और समय

JPA 2.1 जावा 8 में प्रदान किए गए java.time प्रकारों के लिए समर्थन को परिभाषित नहीं करता है। JPA 2.1 बहुसंख्यक कार्यान्वयन इन प्रकारों के लिए समर्थन की पेशकश करते हैं, हालांकि ये सख्ती से विक्रेता एक्सटेंशन बोलते हैं।

DataNucleus के लिए, ये प्रकार केवल बॉक्स से बाहर काम करते हैं, और @Temporal एनोटेशन के साथ युग्मन संभावनाओं की एक विस्तृत श्रृंखला प्रदान करते हैं।

हाइबरनेट के लिए, यदि हाइबरनेट 5.2+ का उपयोग कर रहे हैं, तो उन्हें बॉक्स से बाहर काम करना चाहिए, बस @Basic एनोटेशन का उपयोग करना @Basic । यदि हाइबरनेट 5.0-5.1 का उपयोग कर रहे हैं, तो आपको निर्भरता को जोड़ने की आवश्यकता है org.hibernate:hibernate-java8 । प्रदान किए गए मैपिंग हैं

  • LocalDate date LocalDate
  • Instant , LocalDateTime और ZonedDateTime timestamp

एक विक्रेता-तटस्थ विकल्प किसी भी जावा 8 java.time लिए एक जेपीए 2.1 AttributeConverter को परिभाषित करने के लिए होगा जो कि बनाए रखने के लिए आवश्यक है।

अनुक्रम के साथ इकाई आईडी प्रबंधित

यहां हमारे पास एक वर्ग है और हम चाहते हैं कि पहचान क्षेत्र ( userUid ) का मूल्य डेटाबेस में एक खोज के माध्यम से उत्पन्न हो। इस SEQUENCE को USER_UID_SEQ कहा जाता है, और इसे DBA द्वारा बनाया जा सकता है, या JPA प्रदाता द्वारा बनाया जा सकता है।

@Entity
@Table(name="USER")
public class User implements Serializable {
    private static final long serialVersionUID = 1L;

    @Id
    @SequenceGenerator(name="USER_UID_GENERATOR", sequenceName="USER_UID_SEQ")
    @GeneratedValue(strategy=GenerationType.SEQUENCE, generator="USER_UID_GENERATOR")
    private Long userUid;

    @Basic
    private String userName;
}


Modified text is an extract of the original Stack Overflow Documentation
के तहत लाइसेंस प्राप्त है CC BY-SA 3.0
से संबद्ध नहीं है Stack Overflow