CodeGym /జావా కోర్సు /All lectures for TE purposes /ఆబ్జెక్ట్ మ్యాపింగ్

ఆబ్జెక్ట్ మ్యాపింగ్

All lectures for TE purposes
స్థాయి , పాఠం
అందుబాటులో ఉంది

6.1 సర్వర్‌లో ఫైల్‌లను నిల్వ చేయండి

కొన్నిసార్లు బైనరీ వస్తువులు డేటాబేస్లో సేవ్ చేయబడాలి. ఉదాహరణకు, ఫైళ్లు. ఫైల్ పెద్దది అయితే, దానిని డిస్క్‌లోని ప్రత్యేక ఫోల్డర్‌లో నిల్వ చేయడం మరియు డేటాబేస్లో దాని మార్గాలను నిల్వ చేయడం చాలా సహేతుకమైనది. ఉదాహరణ:

c:\db-files\users\12355\avatar.jpg

మరియు డేటాబేస్లో మేము ఫైల్‌కు సాపేక్ష మార్గాన్ని నిల్వ చేస్తాము:

\12355\avatar.jpg

డేటాబేస్లో సంబంధిత మార్గాన్ని నిల్వ చేయడం సౌకర్యంగా ఉంటుంది, ఎందుకంటే దాని నుండి URLని పొందడం సులభం:

https://storage.codegym.cc/users/12355/avatar.jpg

మేము సర్వర్ పేరుకు సంబంధిత మార్గాన్ని అతికించాము మరియు మేము పూర్తి చేసాము.

6.2 చిత్రాలను నేరుగా డేటాబేస్‌లో నిల్వ చేయండి

అయితే, చిత్రాలు చిన్నవిగా ఉంటే, వాటిని నేరుగా డేటాబేస్లో నిల్వ చేయవచ్చు మరియు బైట్‌ల సమితిగా క్లయింట్‌కు ఇవ్వబడుతుంది. అటువంటి సందర్భాలలో, SQLకి ప్రత్యేక BLOB డేటా రకం ఉంది - బైనరీ లార్జ్ ఆబ్జెక్ట్. లేదా, వాటిలో రెండు కూడా ఉన్నాయి:

  • CLOB - అక్షరం పెద్ద వస్తువు,
  • BLOB - బైనరీ లార్జ్ ఆబ్జెక్ట్.

CLOB చాలా పెద్ద గ్రంథాలను నిల్వ చేయడానికి ఉపయోగించబడుతుంది. BLOB అనేది చిన్న చిత్రాలు, వీడియోలు మరియు ఇలాంటివి వంటి బైనరీ డేటాను నిల్వ చేయడానికి.

ఉదాహరణ:

@Entity
@Table(name="user")
public class User {

    @Id
    private String id;

	@Column(name = "name", columnDefinition="VARCHAR(128)")
    private String name;

	@Lob
	@Column(name = "photo", columnDefinition="BLOB")
    private byte[] photo;

	// ...
}

ఒక పెద్ద వస్తువు ఫీల్డ్‌లో నిల్వ చేయబడిందని ఉల్లేఖన @Lobహైబర్నేట్‌కు చెబుతుంది . మరియు ఇప్పటికే డేటాబేస్లో అన్నింటినీ ఎలా సేవ్ చేయాలనే దాని గురించి మాట్లాడుతుంది.columnDefinition="BLOB"

కొత్త వినియోగదారుని మరియు అతని ఫోటోను డేటాబేస్‌లో సేవ్ చేసే ఉదాహరణ కోడ్‌ను వ్రాద్దాం:

byte[] imageBuffer = Files.readAllBytes(Paths.get("C:/temp/avatar.png"))

User user = new User();
user.setId("1");
user.setName("Zapp");
user.setPhoto(imageBuffer);

session.persist(user);

6.3 XML మరియు JSON

హైబర్నేట్ డేటా రకంగా JSON కోసం ఆసక్తికరమైన మద్దతును కలిగి ఉంది. ఇది ఒకే JSON ఆబ్జెక్ట్‌గా స్ట్రింగ్‌ల HashMapని నిల్వ చేయడానికి మిమ్మల్ని అనుమతిస్తుంది. DBMS JSONతో పని చేయగలిగితే, అది ఇలా కనిపిస్తుంది:

@JdbcTypeCode(SqlTypes.JSON)
private Map<String, String> properties;

హైబర్నేట్ టైప్ ఆబ్జెక్ట్ Map<String, String>ఒకే JSON ఆబ్జెక్ట్‌గా క్రమీకరించబడిందని జాగ్రత్త తీసుకుంటుంది. అలాగే, డేటాబేస్ నుండి ఒక వస్తువును చదివేటప్పుడు, ఇది JSON ఆబ్జెక్ట్‌ని సెట్‌గా మారుస్తుంది Map<String, String>.

హైబర్నేట్ XMLతో సమానమైన పనిని చేయగలదు:

@JdbcTypeCode(SqlTypes.SQLXML)
private Map<String, String> properties;
వ్యాఖ్యలు
TO VIEW ALL COMMENTS OR TO MAKE A COMMENT,
GO TO FULL VERSION