EJB - इकाई संबंध
EJB 3.0 एक-से-एक, एक-से-कई, कई-से-एक, और कई-से-कई रिश्तों की तरह डेटाबेस इकाई संबंधों / मैपिंग को परिभाषित करने का विकल्प प्रदान करता है।
निम्नलिखित प्रासंगिक एनोटेशन हैं -
One-to-One- वस्तुओं का एक-से-एक संबंध होता है। उदाहरण के लिए, एक यात्री एक बार में एक ही टिकट का उपयोग करके यात्रा कर सकता है।
One-to-Many- वस्तुओं का एक से कई संबंध होते हैं। उदाहरण के लिए, एक पिता के कई बच्चे हो सकते हैं।
Many-to-One- वस्तुओं के कई-से-एक संबंध होते हैं। उदाहरण के लिए, एक ही माँ वाले कई बच्चे।
Many-to-Many- वस्तुओं के कई-से-कई संबंध होते हैं। उदाहरण के लिए, एक किताब में कई लेखक हो सकते हैं और एक लेखक कई किताबें लिख सकता है।
हम यहां कईToMany मानचित्रण का उपयोग प्रदर्शित करेंगे। ManyToMany संबंध का प्रतिनिधित्व करने के लिए, निम्नलिखित तीन तालिकाओं की आवश्यकता है -
Book - बुक टेबल, किताबों का रिकॉर्ड होना।
Author - लेखक की तालिका, लेखक के रिकॉर्ड वाले।
Book_Author - बुक ऑथर टेबल, ऊपर बताई गई बुक और ऑथर टेबल का लिंकेज है।
टेबल्स बनाएं
एक तालिका बनाएं book author, book_author डिफ़ॉल्ट डेटाबेस में postgres।
CREATE TABLE book (
book_id integer,
name varchar(50)
);
CREATE TABLE author (
author_id integer,
name varchar(50)
);
CREATE TABLE book_author (
book_id integer,
author_id integer
);
एंटिटी क्लासेस बनाएं
@Entity
@Table(name="author")
public class Author implements Serializable{
private int id;
private String name;
...
}
@Entity
@Table(name="book")
public class Book implements Serializable{
private int id;
private String title;
private Set<Author> authors;
...
}
बुक एंटिटी में कईToMany एनोटेशन का उपयोग करें।
@Entity
public class Book implements Serializable{
...
@ManyToMany(cascade = {CascadeType.PERSIST, CascadeType.MERGE}
, fetch = FetchType.EAGER)
@JoinTable(table = @Table(name = "book_author"),
joinColumns = {@JoinColumn(name = "book_id")},
inverseJoinColumns = {@JoinColumn(name = "author_id")})
public Set<Author> getAuthors() {
return authors;
}
...
}
उदाहरण अनुप्रयोग
आइए हम ईजेबी 3.0 में इकाई संबंधों की वस्तुओं का परीक्षण करने के लिए एक परीक्षण ईजेबी एप्लिकेशन बनाएं।
कदम | विवरण |
---|---|
1 | एक नाम के साथ एक प्रोजेक्ट बना EjbComponent एक पैकेज के तहत com.tutorialspoint.entity के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। EJB में बनाई गई परियोजना का उपयोग करें - इस अध्याय के रूप में दृढ़ता अध्याय EJB अवधारणाओं में एम्बेडेड वस्तुओं को समझने के लिए। |
2 | बनाएं Author.java पैकेज के अंतर्गत com.tutorialspoint.entity के रूप में विस्तार से बताया EJB - आवेदन बनाएं अध्याय। बाकी फाइलों को अपरिवर्तित रखें। |
3 | बनाएं Book.java पैकेज के अंतर्गत com.tutorialspoint.entity । संदर्भ के रूप में ईजेबी - दृढ़ता अध्याय का उपयोग करें । बाकी फाइलों को अपरिवर्तित रखें। |
4 | यह सुनिश्चित करने के लिए एप्लिकेशन को क्लीन एंड बिल्ड करें कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है। |
5 | अंत में, JBoss एप्लिकेशन सर्वर पर जार फ़ाइल के रूप में एप्लिकेशन को तैनात करें। यदि यह अभी तक शुरू नहीं हुआ है तो JBoss एप्लिकेशन सर्वर अपने आप शुरू हो जाएगा। |
6 | अब EJB क्लाइंट बनाएं, जिस प्रकार EJB में समझाया गया है उसी तरह से एक कंसोल आधारित एप्लिकेशन - विषय के तहत एप्लिकेशन अध्याय बनाएंCreate Client to access EJB। |
EJBComponent (EJB मॉड्यूल)
Author.java
package com.tutorialspoint.entity;
import java.io.Serializable;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
@Entity
@Table(name="author")
public class Author implements Serializable{
private int id;
private String name;
public Author() {}
public Author(int id, String name) {
this.id = id;
this.name = name;
}
@Id
@GeneratedValue(strategy= GenerationType.IDENTITY)
@Column(name="author_id")
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String toString() {
return id + "," + name;
}
}
Book.java
package com.tutorialspoint.entity;
import java.io.Serializable;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Table;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
@Entity
@Table(name="book")
public class Book implements Serializable{
private int id;
private String name;
private Set<Author> authors;
public Book() {
}
@Id
@GeneratedValue(strategy= GenerationType.IDENTITY)
@Column(name="book_id")
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public void setAuthors(Set<Author> authors) {
this.authors = authors;
}
@ManyToMany(cascade = {CascadeType.PERSIST, CascadeType.MERGE}
, fetch = FetchType.EAGER)
@JoinTable(table = @Table(name = "book_author"),
joinColumns = {@JoinColumn(name = "book_id")},
inverseJoinColumns = {@JoinColumn(name = "author_id")})
public Set<Author> getAuthors() {
return authors;
}
}
LibraryPersistentBeanRemote.java
package com.tutorialspoint.stateless;
import com.tutorialspoint.entity.Book;
import java.util.List;
import javax.ejb.Remote;
@Remote
public interface LibraryPersistentBeanRemote {
void addBook(Book bookName);
List<Book> getBooks();
}
LibraryPersistentBean.java
package com.tutorialspoint.stateless;
import com.tutorialspoint.entity.Book;
import java.util.List;
import javax.ejb.Stateless;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
@Stateless
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
public LibraryPersistentBean() {
}
@PersistenceContext(unitName="EjbComponentPU")
private EntityManager entityManager;
public void addBook(Book book) {
entityManager.persist(book);
}
public List<Book> getBooks() {
return entityManager.createQuery("From Book").getResultList();
}
}
जैसे ही आप JBOSS पर EjbComponent प्रोजेक्ट को तैनात करते हैं, jboss लॉग को नोटिस करें।
JBoss ने स्वचालित रूप से हमारे सत्र सेम के लिए एक JNDI प्रविष्टि बनाई है - LibraryPersistentBean/remote।
हम इस लुकअप स्ट्रिंग का उपयोग दूरस्थ प्रकार की दूरस्थ व्यावसायिक वस्तु प्राप्त करने के लिए करेंगे - com.tutorialspoint.interceptor.LibraryPersistentBeanRemote
JBoss अनुप्रयोग सर्वर लॉग आउटपुट
...
16:30:01,401 INFO [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:
LibraryPersistentBean/remote - EJB3.x Default Remote Business Interface
LibraryPersistentBean/remote-com.tutorialspoint.interceptor.LibraryPersistentBeanRemote - EJB3.x Remote Business Interface
16:30:02,723 INFO [SessionSpecContainer] Starting jboss.j2ee:jar=EjbComponent.jar,name=LibraryPersistentBean,service=EJB3
16:30:02,723 INFO [EJBContainer] STARTED EJB: com.tutorialspoint.interceptor.LibraryPersistentBeanRemote ejbName: LibraryPersistentBean
16:30:02,731 INFO [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:
LibraryPersistentBean/remote - EJB3.x Default Remote Business Interface
LibraryPersistentBean/remote-com.tutorialspoint.interceptor.LibraryPersistentBeanRemote - EJB3.x Remote Business Interface
...
EJBTester (EJB ग्राहक)
jndi.properties
java.naming.factory.initial=org.jnp.interfaces.NamingContextFactory
java.naming.factory.url.pkgs=org.jboss.naming:org.jnp.interfaces
java.naming.provider.url=localhost
इन गुणों का उपयोग जावा नामकरण सेवा की आरंभिक वस्तु को आरंभ करने के लिए किया जाता है।
आरंभिक वस्तु ऑब्जेक्ट का उपयोग स्टेटलेस सेशन बीन देखने के लिए किया जाएगा।
EJBTester.java
package com.tutorialspoint.test;
import com.tutorialspoint.stateful.LibraryBeanRemote;
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;
import javax.naming.InitialContext;
import javax.naming.NamingException;
public class EJBTester {
BufferedReader brConsoleReader = null;
Properties props;
InitialContext ctx;
{
props = new Properties();
try {
props.load(new FileInputStream("jndi.properties"));
} catch (IOException ex) {
ex.printStackTrace();
}
try {
ctx = new InitialContext(props);
} catch (NamingException ex) {
ex.printStackTrace();
}
brConsoleReader =
new BufferedReader(new InputStreamReader(System.in));
}
public static void main(String[] args) {
EJBTester ejbTester = new EJBTester();
ejbTester.testEmbeddedObjects();
}
private void showGUI() {
System.out.println("**********************");
System.out.println("Welcome to Book Store");
System.out.println("**********************");
System.out.print("Options \n1. Add Book\n2. Exit \nEnter Choice: ");
}
private void testEmbeddedObjects() {
try {
int choice = 1;
LibraryPersistentBeanRemote libraryBean =
(LibraryPersistentBeanRemote)
ctx.lookup("LibraryPersistentBean/remote");
while (choice != 2) {
String bookName;
String authorName;
showGUI();
String strChoice = brConsoleReader.readLine();
choice = Integer.parseInt(strChoice);
if (choice == 1) {
System.out.print("Enter book name: ");
bookName = brConsoleReader.readLine();
System.out.print("Enter author name: ");
authorName = brConsoleReader.readLine();
Book book = new Book();
book.setName(bookName);
Author author = new Author();
author.setName(authorName);
Set<Author> authors = new HashSet<Author>();
authors.add(author);
book.setAuthors(authors);
libraryBean.addBook(book);
} else if (choice == 2) {
break;
}
}
List<Book> booksList = libraryBean.getBooks();
System.out.println("Book(s) entered so far: " + booksList.size());
int i = 0;
for (Book book:booksList) {
System.out.println((i+1)+". " + book.getName());
System.out.print("Author: ");
Author[] authors = (Author[])books.getAuthors().toArray();
for(int j=0;j<authors.length;j++) {
System.out.println(authors[j]);
}
i++;
}
} catch (Exception e) {
System.out.println(e.getMessage());
e.printStackTrace();
}finally {
try {
if(brConsoleReader !=null) {
brConsoleReader.close();
}
} catch (IOException ex) {
System.out.println(ex.getMessage());
}
}
}
}
EJBTester निम्नलिखित कार्य करता है -
Jndi.properties से लोड गुण और प्रारंभक ऑब्जेक्ट को प्रारंभ करें।
TestInterceptedEjb () विधि में, jndi लुकअप नाम के साथ किया जाता है - "LibraryPersistenceBean / Remote" दूरस्थ व्यावसायिक ऑब्जेक्ट (स्टेटलेस EJB) प्राप्त करने के लिए।
फिर उपयोगकर्ता को एक लाइब्रेरी स्टोर यूजर इंटरफेस दिखाया जाता है और उसे पसंद चुनने के लिए कहा जाता है।
यदि उपयोगकर्ता 1 में प्रवेश करता है, तो सिस्टम पुस्तक का नाम पूछता है और स्टेटलेस सेशन बीन एडबुक () विधि का उपयोग करके पुस्तक को बचाता है। सत्र बीन डेटाबेस में पुस्तक संग्रहीत कर रहा है।
यदि उपयोगकर्ता 2 में प्रवेश करता है, तो सिस्टम स्टेटलेस सेशन बीन गेटबुक () विधि का उपयोग करके पुस्तकें प्राप्त करता है और बाहर निकलता है।
EJB को एक्सेस करने के लिए क्लाइंट चलाएं
प्रोजेक्ट एक्सप्लोरर में EJBTester.java का पता लगाएं। EJBTester क्लास पर राइट क्लिक करें और सेलेक्ट करेंrun file।
नेटबीन्स कंसोल में निम्न आउटपुट को सत्यापित करें।
run:
**********************
Welcome to Book Store
**********************
Options
1. Add Book
2. Exit
Enter Choice: 1
Enter book name: learn html5
Enter Author name: Robert
**********************
Welcome to Book Store
**********************
Options
1. Add Book
2. Exit
Enter Choice: 2
Book(s) entered so far: 1
1. learn html5
Author: Robert
BUILD SUCCESSFUL (total time: 21 seconds)