|
Hibernate example source code file (persistent_classes.po)
This example Hibernate source code file (persistent_classes.po) is included in the DevDaily.com
"Java Source Code
Warehouse" project. The intent of this project is to help you "Learn Java by Example" TM.
The Hibernate persistent_classes.po source code
msgid ""
msgstr ""
"Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
"POT-Creation-Date: 2010-02-04T04:51:22\n"
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
"Language-Team: LANGUAGE <LL@li.org>\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
#. Tag: title
#, no-c-format
msgid "Persistent Classes"
msgstr "ì˜ì† í´ëž˜ìŠ¤ë“¤"
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"Persistent classes are classes in an application that implement the entities "
"of the business problem (e.g. Customer and Order in an E-commerce "
"application). Not all instances of a persistent class are considered to be "
"in the persistent state. For example, an instance can instead be transient "
"or detached."
msgstr ""
"ì˜ì† í´ëž˜ìŠ¤ë“¤ì€ 비지니스 ë¬¸ì œì˜ ì—”í‹°í‹°ë“¤(예를 들어 E-Commerce 어플리케ì´ì…˜ì—"
"ì„œ ê³ ê°ì´ë‚˜ 주문)ì„ êµ¬í˜„í•˜ëŠ” 어플리케ì´ì…˜ ë‚´ì˜ í´ëž˜ìŠ¤ë“¤ì´ë‹¤. ì˜ì† í´ëž˜ìŠ¤ë“¤ì˜ "
"ì¸ìŠ¤í„´ìŠ¤ë“¤ì€ ì˜ì† ìƒíƒœì— 있는 것으로 ì „í˜€ 간주ë˜ì§€ 않는다 - ëŒ€ì‹ ì— í•˜ë‚˜ì˜ ì¸"
"스턴스는 transient ë˜ëŠ” detached ìƒíƒœì¼ 수 있다."
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"Hibernate works best if these classes follow some simple rules, also known "
"as the Plain Old Java Object (POJO) programming model. However, none of "
"these rules are hard requirements. Indeed, Hibernate3 assumes very little "
"about the nature of your persistent objects. You can express a domain model "
"in other ways (using trees of <literal>Map instances, for example)."
msgstr ""
"Hibernate는 ì´ë“¤ í´ëž˜ìŠ¤ë“¤ì´ Plain Old Java Object (POJO) í”„ë¡œê·¸ëž˜ë° ëª¨í˜•ìœ¼ë¡œ"
"ì„œ ì•Œë ¤ì§„, 몇몇 간단한 ê·œì¹™ë“¤ì„ ë”°ë¥¼ ê²½ìš°ì— ê°€ìž¥ 잘 ë™ìž‘한다. 하지만 ì´ë“¤ ê·œ"
"칙들 중 ì–´ë–¤ ê²ƒë„ ì–´ë ¤ìš´ ì‚¬ì–‘ë“¤ì´ ì•„ë‹ˆë‹¤. ì§„ì • Hibernate3는 ë‹¹ì‹ ì˜ ì˜ì† ê°ì²´"
"ë“¤ì˜ íŠ¹ì§•ì— ëŒ€í•´ 매우 ì ì€ ê²ƒì„ ê°€ì •í•œë‹¤. ë‹¹ì‹ ì€ ë‹¤ë¥¸ 방법들로 ë„ë©”ì¸ ëª¨í˜•ì„ "
"í‘œí˜„í• ìˆ˜ 있다 : 예를 들어 <literal>Map ì¸ìŠ¤í„´ìŠ¤ì˜ íŠ¸ë¦¬ë“¤ì„ ì‚¬ìš©í•˜"
"기."
#. Tag: title
#, no-c-format
msgid "A simple POJO example"
msgstr "간단한 POJO ì˜ˆì œ"
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"Most Java applications require a persistent class representing felines. For "
"example:"
msgstr ""
"ëŒ€ë¶€ë¶„ì˜ ìžë°” 어플리케ì´ì…˜ë“¤ì€ ê³ ì–‘ì´ê³¼ë“¤ì„ 표현하는 ì˜ì† í´ëž˜ìŠ¤ë¥¼ 필요로 í•œ"
"다."
#. Tag: para
#, no-c-format
msgid ""
"The four main rules of persistent classes are explored in more detail in the "
"following sections."
msgstr ""
#. Tag: title
#, no-c-format
msgid "Implement a no-argument constructor"
msgstr "아규먼트 없는 ìƒì„±ìžë¥¼ 구현하ë¼"
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"<literal>Cat has a no-argument constructor. All persistent classes "
"must have a default constructor (which can be non-public) so that Hibernate "
"can instantiate them using <literal>Constructor.newInstance(). It "
"is recommended that you have a default constructor with at least "
"<emphasis>package visibility for runtime proxy generation in "
"Hibernate."
msgstr ""
"<literal>Catì€ ì•„ê·œë¨¼íŠ¸ 없는 ìƒì„±ìžë¥¼ 갖는다. ëª¨ë“ ì˜ì† í´ëž˜ìŠ¤ë“¤ì€ "
"Hibernate는 <literal>Constructor.newInstance()를 사용하여 ê·¸ê²ƒë“¤ì„ "
"초기화 시킬 수 있ë„ë¡ ë””í´íŠ¸ ìƒì„±ìž (publicì´ ì•„ë‹ ìˆ˜ 있다)를 ê°€ì ¸ì•¼ 한다. ìš°"
"리는 Hibernate ë‚´ì—ì„œ 런타임 프ë½ì‹œ ìƒì„±ì„ 위한 ìµœì†Œí•œì˜ <emphasis>패키지 has a property called id. This "
"property maps to the primary key column of a database table. The property "
"might have been called anything, and its type might have been any primitive "
"type, any primitive \"wrapper\" type, <literal>java.lang.String or "
"<literal>java.util.Date. If your legacy database table has "
"composite keys, you can use a user-defined class with properties of these "
"types (see the section on composite identifiers later in the chapter.)"
msgstr ""
"<literal>Catì€ idë¡œ ëª…ëª…ëœ í•˜ë‚˜ì˜ í”„ë¡œí¼í‹°ë¥¼ ê°–"
"는다. ì´ í”„ë¡œí¼í‹°ëŠ” ë°ì´í„°ë² ì´ìŠ¤ í…Œì´ë¸”ì˜ í”„ë¼ì´ë¨¸ë¦¬ 키 컬럼으로 매핑ëœë‹¤. "
"ì´ í”„ë¡œí¼í‹°ëŠ” ì–´ë–¤ 것으로 명명ë ìˆ˜ë„ ìžˆê³ , ê·¸ê²ƒì˜ íƒ€ìž…ì€ ìž„ì˜ì˜ ì›ì‹œ 타입, "
"ì›ì‹œ \"wrapper\" 타입, <literal>java.lang.String ë˜ëŠ” "
"<literal>java.util.Dateì¼ ìˆ˜ 있다. (ë§Œì¼ ë‹¹ì‹ ì˜ ë¦¬ê±°ì‹œ ë°ì´í„°ë² ì´"
"스 í…Œì´ë¸”ì´ composite í‚¤ë“¤ì„ ê°–ê³ ìžˆë‹¤ë©´, ë‹¹ì‹ ì€ ì´ë“¤ íƒ€ìž…ë“¤ì„ ê°€ì§„ ì‚¬ìš©ìž ì •"
"ì˜ í´ëž˜ìŠ¤ë¥¼ ì‚¬ìš©í• ìˆ˜ë„ ìžˆë‹¤ - ë‚˜ì¤‘ì— composite ì‹ë³„ìžë“¤ì— 대한 ì ˆì„ ë³´ë¼)"
#. Tag: para
#, no-c-format
msgid ""
"The identifier property is strictly optional. You can leave them off and let "
"Hibernate keep track of object identifiers internally. We do not recommend "
"this, however."
msgstr ""
"identifier 프로í¼í‹°ëŠ” 엄격하게 옵션ì´ë‹¤. ë‹¹ì‹ ì€ ê·¸ê²ƒì„ ìƒëžµí• ìˆ˜ë„ ìžˆê³ , "
"Hibernateë¡œ 하여금 내부ì 으로 ê°ì²´ ì‹ë³„ìžë“¤ì„ 추ì 하ë„ë¡ í• ìˆ˜ 있다. 하지만 "
"우리는 ì´ê²ƒì„ 권장하지 않는다."
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"In fact, some functionality is available only to classes that declare an "
"identifier property:"
msgstr ""
"사실, ì–´ë–¤ ê¸°ëŠ¥ì€ identifier 프로í¼í‹°ë¥¼ ì„ ì–¸í•˜ëŠ” í´ëž˜ìŠ¤ë“¤ì— 대해서만 ì´ìš© ê°€"
"능하다:"
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"Transitive reattachment for detached objects (cascade update or cascade "
"merge) - see <xref linkend=\"objectstate-transitive\" />"
msgstr ""
"detached ê°ì²´ë“¤ì— 대한 Transitive reattachment(cascade update ë˜ëŠ” cascade "
"merge) - <xref linkend=\"objectstate-transitive\"/>"
#. Tag: para
#, fuzzy, no-c-format
msgid "<literal>Session.saveOrUpdate()"
msgstr "Session.saveOrUpdate()"
#. Tag: para
#, fuzzy, no-c-format
msgid "<literal>Session.merge()"
msgstr "Session.merge()"
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"We recommend that you declare consistently-named identifier properties on "
"persistent classes and that you use a nullable (i.e., non-primitive) type."
msgstr ""
"우리는 ë‹¹ì‹ ì´ ì˜ì† í´ëž˜ìŠ¤ë“¤ì— 대해 ì¼ê´€ë˜ê²Œ ëª…ëª…ëœ identifier 프로í¼í‹°ë“¤ì„ ì„ "
"ì–¸í• ê²ƒì„ ê¶Œìž¥í•œë‹¤. 게다가 우리는 ë‹¹ì‹ ì´ nullable 타입(예를 들어 non-"
"primitive)ì„ ì‚¬ìš©í• ê²ƒì„ ê¶Œìž¥í•œë‹¤."
#. Tag: title
#, no-c-format
msgid "Prefer non-final classes (optional)"
msgstr "finalì´ ì•„ë‹Œ í´ëž˜ìŠ¤ë“¤ì„ ì„ í˜¸í•˜ë¼(옵션)"
#. Tag: para
#, no-c-format
msgid ""
"A central feature of Hibernate, <emphasis>proxies, depends upon "
"the persistent class being either non-final, or the implementation of an "
"interface that declares all public methods."
msgstr ""
"Hibernateì˜ ì¤‘ì‹¬ 특징ì¸, 프ë½ì‹œ(<emphasis>proxies)ë“¤ì€ finalì´ ì•„"
"ë‹Œ ì˜ì† í´ëž˜ìŠ¤ë“¤ ë˜ëŠ” ëª¨ë‘ public 메소드들로 ì„ ì–¸ëœ ì¸í„°íŽ˜ì´ìŠ¤ì˜ êµ¬í˜„ì¸ ì˜ì† "
"í´ëž˜ìŠ¤ë“¤ì— ì˜ì¡´í•œë‹¤."
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"You can persist <literal>final classes that do not implement an "
"interface with Hibernate. You will not, however, be able to use proxies for "
"lazy association fetching which will ultimately limit your options for "
"performance tuning."
msgstr ""
"ë‹¹ì‹ ì€ Hibernateë¡œ ì¸í„°íŽ˜ì´ìŠ¤ë¥¼ 구현하지 ì•Šì€ <literal>final í´ëž˜ìŠ¤"
"ë“¤ì„ ì˜ì†í™” 시킬 수 있지만 ë‹¹ì‹ ì€ lazy ì—°ê´€ 페ì¹(lazy association fetching)"
"ì— ëŒ€í•´ 프ë½ì‹œë“¤ì„ ì‚¬ìš©í• ìˆ˜ ì—†ì„ ê²ƒì´ë‹¤ -ê·¸ê²ƒì€ í¼í¬ë¨¼ìŠ¤ 튜ë‹ì„ 위한 ë‹¹ì‹ ì˜ "
"ì˜µì…˜ë“¤ì„ ì œí•œì‹œí‚¬ 것ì´ë‹¤."
#. Tag: para
#, no-c-format
msgid ""
"You should also avoid declaring <literal>public final methods on "
"the non-final classes. If you want to use a class with a <literal>public "
"final</literal> method, you must explicitly disable proxying by setting "
"<literal>lazy=\"false\"."
msgstr ""
"ë‹¹ì‹ ì€ ë˜í•œ non-final í´ëž˜ìŠ¤ë“¤ ìƒì— <literal>public final 메소드들"
"ì„ ì„ ì–¸í•˜ëŠ” ê²ƒì„ í”¼í•´ì•¼ 한다. ë§Œì¼ ë‹¹ì‹ ì´ <literal>public final ë©”"
"소드를 가진 í´ëž˜ìŠ¤ë¥¼ ì‚¬ìš©í•˜ê³ ìž ì›í• 경우, ë‹¹ì‹ ì€ <literal>lazy=\"false\" declares accessor methods for all its persistent "
"fields. Many other ORM tools directly persist instance variables. It is "
"better to provide an indirection between the relational schema and internal "
"data structures of the class. By default, Hibernate persists JavaBeans style "
"properties and recognizes method names of the form <literal>getFooisFoo and setFoo. If "
"required, you can switch to direct field access for particular properties."
msgstr ""
"<literal>Catì€ ê·¸ê²ƒì˜ ëª¨ë“ ì˜ì† í•„ë“œë“¤ì— ëŒ€í•´ accessor ë©”ì†Œë“œë“¤ì„ "
"ì„ ì–¸í•œë‹¤. ë§Žì€ ë‹¤ë¥¸ ORM ë„êµ¬ë“¤ì€ ì¸ìŠ¤í„´ìŠ¤ ë³€ìˆ˜ë“¤ì„ ì§ì ‘ ì˜ì†í™” 시킨다. 우리"
"는 관계형 스키마와 í´ëž˜ìŠ¤ì˜ 내부ì ì¸ ë°ì´í„° 구조들 사ì´ì— ê°„ì ‘ì ì¸ ìˆ˜ë‹¨ì„ ì œ"
"공하는 ê²ƒì´ ë” ì¢‹ë‹¤ê³ ë¯¿ê³ ìžˆë‹¤. ë””í´íŠ¸ë¡œ Hibernate는 ìžë°”빈즈 ìŠ¤íƒ€ì¼ í”„ë¡œí¼"
"í‹°ë“¤ì„ ì˜ì†í™” ì‹œí‚¤ê³ , <literal>getFoo, isFoo와 "
"<literal>setFoo 형ì‹ì˜ 메소드 ì´ë¦„ë“¤ì„ ì¸ì§€í•œë‹¤. ë‹¹ì‹ ì€ ì§„ì •ìœ¼ë¡œ 특"
"ì • 프로í¼í‹°ì— 대한 ì§ì ‘ì ì¸ í•„ë“œ ì ‘ê·¼ìœ¼ë¡œ ì „í™˜í• ìˆ˜ë„ ìžˆë‹¤."
#. Tag: para
#, no-c-format
msgid ""
"Properties need <emphasis>not be declared public - Hibernate can "
"persist a property with a default, <literal>protected or "
"<literal>private get / set pair."
msgstr ""
"프로í¼í‹°ë“¤ì€ public으로 ì„ ì–¸ë 필요가 <emphasis>없다 - Hibernate"
"는 ë””í´íŠ¸ë¡œ <literal>protected get/set ìŒ ë˜ëŠ” private. For example:"
msgstr ""
"서브í´ëž˜ìŠ¤ëŠ” ë˜í•œ 첫 번째 규칙들과 ë‘ ë²ˆì§¸ ê·œì¹™ë“¤ì„ ì£¼ì‹œí•´ì•¼ 한다. ê·¸ê²ƒì€ ìŠˆ"
"í¼í´ëž˜ìŠ¤ <literal>Cat으로부터 ê·¸ê²ƒì˜ identifier 프로í¼í‹°ë¥¼ ìƒì†ë°›ëŠ”"
"다."
#. Tag: title
#, no-c-format
msgid ""
"Implementing <literal>equals() and hashCode()"
msgstr "<literal>equals()와 hashCode() 구현하기"
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"You have to override the <literal>equals() and hashCode()"
"</literal> methods if you:"
msgstr ""
"ë§Œì¼ ë‹¹ì‹ ì´ ë‹¤ìŒì˜ 경우ë¼ë©´, ë‹¹ì‹ ì€ <literal>equals()와 "
"<literal>hashCode() ë©”ì†Œë“œë“¤ì„ ì˜¤ë²„ë¼ì´ë“œ 시켜야 한다."
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"intend to put instances of persistent classes in a <literal>Set "
"(the recommended way to represent many-valued associations); <emphasis>and ì†ì— ì˜ì† í´ëž˜ìŠ¤ë“¤ì˜ ì¸ìŠ¤í„´ìŠ¤ë“¤ì„ ì§‘ì–´ë„£ê³ ìž ì˜"
"ë„í•˜ê³ (many-valued ì—°ê´€ë“¤ì— ëŒ€í•´ 권장ë˜ëŠ” 방법) <emphasis>ê·¸ë¦¬ê³ "
#. Tag: para
#, no-c-format
msgid "intend to use reattachment of detached instances"
msgstr "detached ì¸ìŠ¤í„´ìŠ¤ë“¤ì˜ reattachment(재첨부)를 ì‚¬ìš©í•˜ê³ ìž ì˜ë„하는"
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"Hibernate guarantees equivalence of persistent identity (database row) and "
"Java identity only inside a particular session scope. When you mix instances "
"retrieved in different sessions, you must implement <literal>equals()hashCode() if you wish to have meaningful "
"semantics for <literal>Sets."
msgstr ""
"Hibernate는 íŠ¹ì • session 범위 ë‚´ì—서만 persistent identity(ë°ì´í„°ë² ì´ìŠ¤ í–‰)"
"ê³¼ Java identityì˜ ê°™ìŒì„ 보장한다. ë”°ë¼ì„œ 우리가 다른 세션들ì—ì„œ ê²€ìƒ‰ëœ ì¸ìŠ¤"
"í„´ìŠ¤ë“¤ì„ í˜¼í•©ì‹œí‚¤ìžë§ˆìž, 우리가 <literal>Setë“¤ì— ëŒ€í•´ ìœ ì˜ë¯¸í•˜ê²Œ 만"
"ë“¤ê³ ìž ì›í• 경우, 우리는 <literal>equals()와 hashCode()/"
"<literal>hashCode() by comparing the identifier value of both "
"objects. If the value is the same, both must be the same database row, "
"because they are equal. If both are added to a <literal>Set, you "
"will only have one element in the <literal>Set). Unfortunately, "
"you cannot use that approach with generated identifiers. Hibernate will only "
"assign identifier values to objects that are persistent; a newly created "
"instance will not have any identifier value. Furthermore, if an instance is "
"unsaved and currently in a <literal>Set, saving it will assign an "
"identifier value to the object. If <literal>equals() and "
"<literal>hashCode() are based on the identifier value, the hash "
"code would change, breaking the contract of the <literal>Set. See "
"the Hibernate website for a full discussion of this problem. This is not a "
"Hibernate issue, but normal Java semantics of object identity and equality."
msgstr ""
"가장 명백한 ë°©ë²•ì€ ë‘ ê°ì²´ë“¤ì˜ identifier ê°’ì„ ë¹„êµí•¨ìœ¼ë¡œì¨ <literal>equals()"
"</literal>/hashCode()를 구현하는 것ì´ë‹¤. ë§Œì¼ ê·¸ ê°’ì´ ë™ì¼"
"하다면, 둘다 ë™ì¼í•œ ë°ì´í„°ë² ì´ìŠ¤ í–‰ì´ì–´ì•¼ í•˜ê³ , 그러므로 ê·¸ê²ƒë“¤ì€ ê°™ë‹¤(둘다 "
"í•˜ë‚˜ì˜ <literal>Setì— ì¶”ê°€ë˜ëŠ” 경우ì—, 우리는 Set ì†ì— ìžˆì„ ê²½ìš°ì—, ê·¸ê²ƒì„ ì €ìž¥í•˜ëŠ”ê²ƒì€ í•˜ë‚˜ì˜ ì‹ë³„ìž ê°’"
"ì„ ê·¸ ê°ì²´ì—게 í• ë‹¹í• ê²ƒì´ë‹¤. ë§Œì¼ <literal>equals()와 "
"<literal>hashCode()ê°€ ê·¸ ì‹ë³„ìž ê°’ì— ê¸°ì´ˆí• ê²½ìš°, hash 코드는 "
"<literal>Setì˜ ê³„ì•½ì„ íŒŒê¸°í•˜ì—¬ 변경ë 것ì´ë‹¤. ì´ ë¬¸ì œì— ëŒ€í•œ ì „ì²´ "
"ë…¼ì˜ì— 대해서는 Hibernate 웹 사ì´íŠ¸ë¥¼ ë³´ë¼. ì´ê²ƒì€ Hibernate ìŸì ì´ ì•„ë‹Œ, ê°"
"ì²´ identity와 equalityì— ê´€í•œ 통ìƒì˜ ìžë°” ì˜ë¯¸ë¡ ìž„ì„ ë…¸íŠ¸í•˜ë¼."
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"It is recommended that you implement <literal>equals() and "
"<literal>hashCode() using Business key equalityequals() "
"method compares only the properties that form the business key. It is a key "
"that would identify our instance in the real world (a <emphasis>natural를 사용하여 equals"
"()</literal>와 hashCode()를 êµ¬í˜„í• ê²ƒ 권장한다. Business "
"key equality는 <literal>equals() 메소드가 비지니스 키, 즉 실세계ì—"
"ì„œ ìš°ë¦¬ì˜ ì¸ìŠ¤í„´ìŠ¤ë¥¼ ì‹ë³„하게 ë 키(<emphasis>natural 후보 키)를 "
"형성하는 프로í¼í‹°ë“¤ë§Œì„ 비êµí•œë‹¤ëŠ” ì ì„ ì˜ë¯¸í•œë‹¤ :"
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"A business key does not have to be as solid as a database primary key "
"candidate (see <xref linkend=\"transactions-basics-identity\" />). Immutable "
"or unique properties are usually good candidates for a business key."
msgstr ""
"í•˜ë‚˜ì˜ ë¹„ì§€ë‹ˆìŠ¤ 키는 ë°ì´í„°ë² ì´ìŠ¤ 프ë¼ì´ë¨¸ë¦¬ 키 후보 ë§Œí¼ ê²¬ê³ í•˜ì§€ 않아야 í•œ"
"다(<xref linkend=\"transactions-basics-identity\"/>를 ë³´ë¼). 대개 ë³€ê²½í• ìˆ˜ "
"없는 프로í¼í‹° ë˜ëŠ” ìœ ì¼í•œ(unique) 프로í¼í‹°ëŠ” 대개 비지니스 í‚¤ì— ëŒ€í•œ ì¢‹ì€ í›„"
"보들ì´ë‹¤."
#. Tag: title
#, no-c-format
msgid "Dynamic models"
msgstr "ë™ì ì¸ ëª¨í˜•ë“¤"
#. Tag: title
#, no-c-format
msgid "Note"
msgstr ""
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"<emphasis>The following features are currently considered experimental and "
"may change in the near future.</emphasis>"
msgstr ""
"ë‹¤ìŒ íŠ¹ì§•ë“¤ì€ í˜„ìž¬ 실험ì 으로 ê³ ë ¤ë˜ê³ 있으며 장래ì—는 변경ë 수 있ìŒì„ 노트"
"하ë¼."
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"Persistent entities do not necessarily have to be represented as POJO "
"classes or as JavaBean objects at runtime. Hibernate also supports dynamic "
"models (using <literal>Maps of Maps at runtime) "
"and the representation of entities as DOM4J trees. With this approach, you "
"do not write persistent classes, only mapping files."
msgstr ""
"ì˜ì† ì—”í‹°í‹°ë“¤ì€ ë°˜ë“œì‹œ ì‹¤í–‰ì‹œì— POJO í´ëž˜ìŠ¤ë“¤ë¡œ ë˜ëŠ” ìžë°”빈즈 ê°ì²´ë“¤ë¡œ 표현ë˜"
"ì–´ì•¼í• í•„ìš”ëŠ” 없다. Hibernate는 ë˜í•œ (실행 ì‹œì— <literal>Mapë“¤ì„ ê°€"
"진 <literal>Mapë“¤ì„ ì‚¬ìš©í•˜ì—¬) ë™ì ì¸ ëª¨í˜•ë“¤ì„ ì§€ì›í•˜ê³ DOM4J 트리들"
"로서 ì—”í‹°í‹°ë“¤ì— ëŒ€í•œ í‘œí˜„ì„ ì§€ì›í•œë‹¤. ì´ ì ‘ê·¼ë²•ìœ¼ë¡œ, ë‹¹ì‹ ì€ ì˜ì† í´ëž˜ìŠ¤ë“¤ì„ "
"작성하지 ì•Šê³ , ì˜¤ì§ ë§¤í•‘ 파ì¼ë“¤ ë§Œì„ ìž‘ì„±í•œë‹¤."
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"By default, Hibernate works in normal POJO mode. You can set a default "
"entity representation mode for a particular <literal>SessionFactorydefault_entity_mode configuration "
"option (see <xref linkend=\"configuration-optional-properties\" />)."
msgstr ""
"ë””í´íŠ¸ë¡œ, Hibernate는 í†µì‚°ì˜ POJO 모드로 ë™ìž‘한다. ë‹¹ì‹ ì€ "
"<literal>default_entity_mode 구성 ì˜µì…˜ì„ ì‚¬ìš©í•˜ì—¬ 특별한 "
"<literal>SessionFactoryì— ëŒ€í•´ ë””í´íŠ¸ 엔티티 표현 모드를 ì„¤ì •í• ìˆ˜ "
"있다 (<xref linkend=\"configuration-optional-properties\"/>ì„ ë³´ë¼)."
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"The following examples demonstrate the representation using <literal>Mapentity-name has "
"to be declared instead of, or in addition to, a class name:"
msgstr ""
"ë‹¤ìŒ ì˜ˆì œë“¤ì€<literal>Mapë“¤ì„ ì‚¬ìš©í•˜ëŠ” í‘œí˜„ì„ ì„¤ëª…í•œë‹¤. ë¨¼ì € 매핑 "
"파ì¼ì—ì„œ, <literal>entity-nameì€ í´ëž˜ìŠ¤ ì´ë¦„ ëŒ€ì‹ ì—(ë˜ëŠ” í´ëž˜ìŠ¤ ì´"
"ë¦„ì— ë§ë¶™ì—¬) ì„ ì–¸ë˜ì–´ì•¼ 한다:"
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"Even though associations are declared using target class names, the target "
"type of associations can also be a dynamic entity instead of a POJO."
msgstr ""
"심지어 ë¹„ë¡ ì—°ê´€ë“¤ì´ ëŒ€ìƒ(target) í´ëž˜ìŠ¤ ì´ë¦„ë“¤ì„ ì‚¬ìš©í•˜ì—¬ ì„ ì–¸ë 지ë¼ë„, ì—°ê´€"
"ë“¤ì˜ ëŒ€ìƒ(target) íƒ€ìž…ì€ ë˜í•œ POJOê°€ ì•„ë‹Œ ë™ì ì¸ ì—”í‹°í‹°ì¼ ìˆ˜ 있ìŒì„ 노트하ë¼."
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"After setting the default entity mode to <literal>dynamic-map for "
"the <literal>SessionFactory, you can, at runtime, work with "
"<literal>Maps of Maps:"
msgstr ""
"<literal>SessionFactoryì— ëŒ€í•œ ë””í´íŠ¸ 엔티티 모드를 "
"<literal>dynamic-map으로 ì„¤ì •í•œ 후ì—, 우리는 Map"
"ë“¤ì„ ê°€ì§„ <literal>Mapë“¤ì— ëŒ€í•´ 실행 ì‹œì— ìž‘ì—…í• ìˆ˜ 있다:"
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"One of the main advantages of dynamic mapping is quick turnaround time for "
"prototyping, without the need for entity class implementation. However, you "
"lose compile-time type checking and will likely deal with many exceptions at "
"runtime. As a result of the Hibernate mapping, the database schema can "
"easily be normalized and sound, allowing to add a proper domain model "
"implementation on top later on."
msgstr ""
"dynamic ë§¤í•‘ì˜ ìž¥ì ë“¤ì€ ì—”í‹°í‹° í´ëž˜ìŠ¤ êµ¬í˜„ì— ëŒ€í•œ í•„ìš” ì—†ì´ë„ í”„ë¡œí† íƒ€ì´í•‘ì„ "
"위한 ë¹ ë¥¸ ì „í™˜ 시간ì´ë‹¤. 하지만 ë‹¹ì‹ ì€ ì»´íŒŒì¼ ì‹œ 타입 ì²´í‚¹ì„ ìžƒê³ ì‹¤í–‰ ì‹œì— "
"ë§Žì€ ì˜ˆì™¸ìƒí™©ë“¤ì„ 다루게 ë 것ì´ë‹¤. Hibernate 매핑 ë•ë¶„ì—, ë‚˜ì¤‘ì— ê³ ìœ í•œ ë„ë©”"
"ì¸ ëª¨í˜• êµ¬í˜„ì„ ìƒë‹¨ì— 추가하는 ê²ƒì´ í—ˆìš©ë˜ì–´ì„œ, ë°ì´í„°ë² ì´ìŠ¤ 스키마가 쉽게 ì •"
"규화 ë˜ê³ 소리가 ìš¸ë ¤ í¼ì§ˆ 수 있다."
#. Tag: para
#, no-c-format
msgid ""
"Entity representation modes can also be set on a per <literal>Session ê¸°ì¤€ì— ëŒ€í•´ "
"ì„¤ì •ë 수 있다:"
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"Please note that the call to <literal>getSession() using an "
"<literal>EntityMode is on the Session API, not "
"the <literal>SessionFactory. That way, the new Sessionclose() on the secondary Session를 사용하는 getSession()ì— ëŒ€"
"í•œ í˜¸ì¶œì€ <literal>SessionFactoryê°€ ì•„ë‹Œ, Sessionì€ ê¸°ë³¸ JDBC 커넥션, 트랜ìžì…˜, ê·¸ë¦¬ê³ ë‹¤ë¥¸ 컨í…스"
"트 ì •ë³´ë¥¼ ê³µìœ í•œë‹¤. ì´ê²ƒì€ ë‹¹ì‹ ì´ ë‘ ë²ˆì§¸ <literal>Session ìƒì—ì„œ "
"<literal>flush()와 close()를 호출하지 ë§ì•„야 하"
"ê³ , ë˜í•œ 트랜ìžì…˜ ë° ì»¤ë„¥ì…˜ 핸들ë§ì„ ì£¼ëœ ìž‘ì—… 단위ì—게 맡긴다는 ì ì„ ì˜ë¯¸í•œ"
"다."
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"More information about the XML representation capabilities can be found in "
"<xref linkend=\"xml\" />."
msgstr ""
"XML 표현 ê°€ìš©ì„±ë“¤ì— ëŒ€í•œ 추가 ì •ë³´ëŠ” <xref linkend=\"xml\"/>ì—ì„œ ì°¾ì„ ìˆ˜ 있"
"다."
#. Tag: title
#, no-c-format
msgid "Tuplizers"
msgstr "Tuplizer들"
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"<literal>org.hibernate.tuple.Tuplizer, and its sub-interfaces, are "
"responsible for managing a particular representation of a piece of data "
"given that representation's <literal>org.hibernate.EntityMode. If "
"a given piece of data is thought of as a data structure, then a tuplizer is "
"the thing that knows how to create such a data structure and how to extract "
"values from and inject values into such a data structure. For example, for "
"the POJO entity mode, the corresponding tuplizer knows how create the POJO "
"through its constructor. It also knows how to access the POJO properties "
"using the defined property accessors."
msgstr ""
"<literal>org.hibernate.tuple.Tuplizer, ê·¸ë¦¬ê³ ê·¸ê²ƒì˜ ì„œë¸Œ-ì¸í„°íŽ˜ì´"
"ìŠ¤ë“¤ì€ ë°ì´í„°ì˜ ì¡°ê°ì— 대한 특별한 í‘œí˜„ì˜ <literal>org.hibernate.EntityModeorg.hibernate.tuple.component."
"ComponentTuplizer</literal> ì¸í„°íŽ˜ì´ìŠ¤ì— ì˜í•´ 표현ë˜ëŠ” ë‘ ê°€ì§€ ê³ ê¸‰ ìœ í˜•ì˜ "
"Tuplizerë“¤ì´ ì¡´ìž¬í•œë‹¤. <literal>EntityTuplizerë“¤ì€ ì—”í‹°í‹°ë“¤ì— ê´€í•´"
"서는 ìœ„ì— ì–¸ê¸‰ëœ ê³„ì•½ë“¤ì„ ë§¤í•‘í• ì±…ìž„ì´ ìžˆëŠ” 반면ì—, "
"<literal>ComponentTuplizerë“¤ì€ ì»´í¬ë„ŒíŠ¸ë“¤ì— ëŒ€í•´ì„œë„ ë™ì¼í•œ ê²ƒì„ í–‰"
"한다."
#. Tag: para
#, no-c-format
msgid ""
"There are two high-level types of Tuplizers, represented by the <literal>org."
"hibernate.tuple.entity.EntityTuplizer</literal> and org.hibernate."
"tuple.component.ComponentTuplizer</literal> interfaces. "
"<literal>EntityTuplizers are responsible for managing the above "
"mentioned contracts in regards to entities, while "
"<literal>ComponentTuplizers do the same for components."
msgstr ""
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"Users can also plug in their own tuplizers. Perhaps you require that a "
"<literal>java.util.Map implementation other than java."
"util.HashMap</literal> be used while in the dynamic-map entity-mode. Or "
"perhaps you need to define a different proxy generation strategy than the "
"one used by default. Both would be achieved by defining a custom tuplizer "
"implementation. Tuplizer definitions are attached to the entity or component "
"mapping they are meant to manage. Going back to the example of our customer "
"entity:"
msgstr ""
"사용ìžë“¤ì€ ë˜í•œ 그들 ìžì‹ ì˜ tuplizerë“¤ì„ í”ŒëŸ¬ê·¸ 시킬 수 있다. 아마 ë‹¹ì‹ ì€ "
"dynamic-map entity-mode ë™ì•ˆì— 사용ë˜ëŠ” <literal>java.util.HashMap "
"ëŒ€ì‹ ì— í•˜ë‚˜ì˜ <literal>java.util.Map êµ¬í˜„ì„ í•„ìš”ë¡œ 한다; ë˜ëŠ” 아마 "
"ë‹¹ì‹ ì€ ë””í´íŠ¸ë¡œ 사용ë˜ëŠ” ë°©ë„ ë³´ë‹¤ëŠ” í•˜ë‚˜ì˜ ë‹¤ë¥¸ 다른 프ë¦ì‹œ 산출 ë°©ë„를 í•„ìš”"
"ë¡œ 한다. 둘다 í•˜ë‚˜ì˜ ë§žì¶¤í˜• tuplizer를 ì •ì˜í•¨ìœ¼ë¡œì¨ 성취ë 것ì´ë‹¤. Tuplizer"
"들 ì •ì˜ë“¤ì€ ê·¸ê²ƒë“¤ì´ ê´€ë¦¬í• ìˆ˜ë‹¨ì¸ ì—”í‹°í‹° 매핑 ë˜ëŠ” ì»´í¬ë„ŒíŠ¸ ë§¤í•‘ì— ì²¨ë¶€ëœ"
"다. ìš°ë¦¬ì˜ ê³ ê° ì—”í‹°í‹°ì— ëŒ€í•œ ì˜ˆì œë¡œ ë˜ëŒì•„가면:"
#. Tag: title
#, no-c-format
msgid "EntityNameResolvers"
msgstr ""
#. Tag: para
#, no-c-format
msgid ""
"The <interfacename>org.hibernate.EntityNameResolver "
"interface is a contract for resolving the entity name of a given entity "
"instance. The interface defines a single method "
"<methodname>resolveEntityName which is passed the entity "
"instance and is expected to return the appropriate entity name (null is "
"allowed and would indicate that the resolver does not know how to resolve "
"the entity name of the given entity instance). Generally speaking, an "
"<interfacename>org.hibernate.EntityNameResolver is going to "
"be most useful in the case of dynamic models. One example might be using "
"proxied interfaces as your domain model. The hibernate test suite has an "
"example of this exact style of usage under the <package>org.hibernate.test."
"dynamicentity.tuplizer2</package>. Here is some of the code from that "
"package for illustration."
msgstr ""
#. Tag: para
#, no-c-format
msgid ""
"In order to register an <interfacename>org.hibernate.EntityNameResolvergetEntityNameResolvers "
"method."
msgstr ""
#. Tag: para
#, no-c-format
msgid ""
"Register it with the <classname>org.hibernate.impl.SessionFactoryImplorg."
"hibernate.SessionFactory</interfacename>) using the "
"<methodname>registerEntityNameResolver method."
msgstr ""
#~ msgid "There are four main rules to follow here:"
#~ msgstr "ì¤€ìˆ˜í• ë„¤ ê°œì˜ ì£¼ìš” ê·œì¹™ë“¤ì´ ë‹¤ìŒì— 있다:"
#~ msgid ""
#~ "TODO: Document user-extension framework in the property and proxy packages"
#~ msgstr ""
#~ "TODO: property 패키지와 proxy 패키지 ë‚´ì— user-extension í”„ë ˆìž„ì›ì„ 문서"
#~ "í™” í• ê²ƒ."
Other Hibernate examples (source code examples)
Here is a short list of links related to this Hibernate persistent_classes.po source code file:
|