|
Hibernate example source code file (association_mapping.po)
This example Hibernate source code file (association_mapping.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 association_mapping.po source code
# translation of association_mapping.po to
# Xi Huang <xhuang@redhat.com>, 2006.
# Xi HUANG <xhuang@redhat.com>, 2007, 2009.
# translation of Collection_Mapping.po to
msgid ""
msgstr ""
"Project-Id-Version: association_mapping\n"
"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
"POT-Creation-Date: 2010-02-10T07:25:34\n"
"PO-Revision-Date: 2009-11-03 11:04+1000\n"
"Last-Translator: Xi HUANG <xhuang@redhat.com>\n"
"Language-Team: <en@li.org>\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
"X-Generator: KBabel 1.11.4\n"
#. Tag: title
#, no-c-format
msgid "Association Mappings"
msgstr "å…³è”å…³ç³»æ˜ å°„"
#. Tag: title
#, no-c-format
msgid "Introduction"
msgstr "介ç»"
#. Tag: para
#, no-c-format
msgid ""
"Association mappings are often the most difficult thing to implement "
"correctly. In this section we examine some canonical cases one by one, "
"starting with unidirectional mappings and then bidirectional cases. We will "
"use <literal>Person and Address in all the "
"examples."
msgstr ""
"å…³è”å…³ç³»æ˜ å°„é€šå¸¸æƒ…å†µæ˜¯æœ€éš¾é…ç½®æ£ç¡®çš„。在这个部分ä¸ï¼Œæˆ‘们从å•å‘å…³ç³»æ˜ å°„å¼€å§‹ï¼Œ"
"然åŽè€ƒè™‘åŒå‘å…³ç³»æ˜ å°„ï¼Œé€æ¥è®²è§£å…¸åž‹çš„案例。在所有的例åä¸ï¼Œæˆ‘们都使将用 "
"<literal>Person 和 Address。"
#. Tag: para
#, no-c-format
msgid ""
"Associations will be classified by multiplicity and whether or not they map "
"to an intervening join table."
msgstr ""
"æˆ‘ä»¬æ ¹æ®æ˜ 射关系是å¦æ¶‰åŠè¿žæŽ¥è¡¨ä»¥åŠå¤šæ ·æ€§ï¼ˆmultiplicity)æ¥åˆ’分关è”类型。 "
#. Tag: para
#, no-c-format
msgid ""
"Nullable foreign keys are not considered to be good practice in traditional "
"data modelling, so our examples do not use nullable foreign keys. This is "
"not a requirement of Hibernate, and the mappings will work if you drop the "
"nullability constraints."
msgstr ""
"åœ¨ä¼ ç»Ÿçš„æ•°æ®å»ºæ¨¡ä¸ï¼Œå…许为 Null 值的外键被认为是一ç§ä¸å¥½çš„å®žè·µï¼Œå› æ¤æˆ‘们所有"
"的例åä¸éƒ½ä½¿ç”¨ä¸å…许为 Null 的外键。这并ä¸æ˜¯ Hibernateçš„ è¦æ±‚,å³ä½¿ä½ åˆ é™¤æŽ‰ä¸"
"å…许为 Null 的约æŸï¼ŒHibernate æ˜ å°„ä¸€æ ·å¯ä»¥å·¥ä½œçš„很好。 "
#. Tag: title
#, no-c-format
msgid "Unidirectional associations"
msgstr "å•å‘å…³è”(Unidirectional associations)"
#. Tag: title
#, no-c-format
msgid "Many-to-one"
msgstr "多对一(many-to-one) "
#. Tag: para
#, no-c-format
msgid ""
"A <emphasis>unidirectional many-to-one association is the most "
"common kind of unidirectional association."
msgstr "<emphasis>å•å‘ many-to-one å…³è”是最常è§çš„å•å‘å…³è”关系。"
#. Tag: title
#, no-c-format
msgid "One-to-one"
msgstr "一对一(One-to-one)"
#. Tag: para
#, no-c-format
msgid ""
"A <emphasis>unidirectional one-to-one association on a foreign keyå’Œå•å‘多对一关è”通常使用一个特定的 id 生æˆ"
"器,然而在这个例åä¸æˆ‘们掉æ¢äº†å…³è”çš„æ–¹å‘:"
#. Tag: title
#, no-c-format
msgid "One-to-many"
msgstr "一对多(one-to-many) "
#. Tag: para
#, no-c-format
msgid ""
"A <emphasis>unidirectional one-to-many association on a foreign key是一ç§å¾ˆå°‘è§çš„情况,我们ä¸æŽ¨"
"è使用它。"
#. Tag: para
#, no-c-format
msgid "You should instead use a join table for this kind of association."
msgstr "我们认为对于这ç§å…³è”关系最好使用连接表。 "
#. Tag: title
#, no-c-format
msgid "Unidirectional associations with join tables"
msgstr "使用连接表的å•å‘å…³è”(Unidirectional associations with join tables)"
#. Tag: para
#, no-c-format
msgid ""
"A <emphasis>unidirectional one-to-many association on a join tableunique=\"true\" 应该优先被采用。请注æ„,通过"
"指定<literal>unique=\"true\",我们å¯ä»¥æŠŠå¤šæ ·æ€§ä»Žå¤šå¯¹å¤šæ”¹å˜ä¸ºä¸€å¯¹"
"多。"
#. Tag: para
#, no-c-format
msgid ""
"A <emphasis>unidirectional many-to-one association on a join table在关è”关系å¯é€‰çš„情况下应用也很"
"æ™®é。例如:"
#. Tag: para
#, no-c-format
msgid ""
"A <emphasis>unidirectional one-to-one association on a join table "
"is possible, but extremely unusual."
msgstr ""
"<emphasis>基于连接表的å•å‘一对一关è”也是å¯è¡Œçš„,但éžå¸¸å°‘è§ã€‚"
#. Tag: title
#, no-c-format
msgid "Many-to-many"
msgstr "多对多(many-to-many) "
#. Tag: para
#, no-c-format
msgid ""
"Finally, here is an example of a <emphasis>unidirectional many-to-many "
"association</emphasis>."
msgstr "最åŽï¼Œè¿™é‡Œæ˜¯ä¸€ä¸ª<emphasis>å•å‘多对多关è”的例å。"
#. Tag: title
#, no-c-format
msgid "Bidirectional associations"
msgstr "åŒå‘å…³è”(Bidirectional associations)"
#. Tag: title
#, no-c-format
msgid "one-to-many / many-to-one"
msgstr "一对多(one to many)/多对一(many to one) "
#. Tag: para
#, no-c-format
msgid ""
"A <emphasis>bidirectional many-to-one association is the most "
"common kind of association. The following example illustrates the standard "
"parent/child relationship."
msgstr ""
"<emphasis>åŒå‘å¤šå¯¹ä¸€å…³è” æ˜¯æœ€å¸¸è§çš„å…³è”关系。下é¢çš„例å解释了这ç§"
"æ ‡å‡†çš„çˆ¶/åå…³è”关系。"
#. Tag: para
#, no-c-format
msgid ""
"If you use a <literal>List, or other indexed collection, set the "
"<literal>key column of the foreign key to not null and insert=\"false"
"\"</literal>:"
msgstr ""
"å¦‚æžœä½ ä½¿ç”¨ <literal>List(或者其他有åºé›†åˆç±»ï¼‰ï¼Œä½ 需è¦è®¾ç½®å¤–键对应"
"的 <literal>key 列为 not null。Hibernate 将从集"
"åˆç«¯ç®¡ç†å…³è”,维护æ¯ä¸ªå…ƒç´ 的索引,并通过设置 <literal>update=\"false\"insert=\"false\" æ¥å¯¹å¦ä¸€ç«¯åå‘æ“作。"
#. Tag: para
#, no-c-format
msgid ""
"If the underlying foreign key column is <literal>NOT NULL, it is "
"important that you define <literal>not-null=\"true\" on the "
"<literal><key> element of the collection mapping. Do not "
"only declare <literal>not-null=\"true\" on a possible nested "
"<literal><column> element, but on the <key> å…ƒç´ å¯¹åº”çš„åº•å±‚å¤–é”®å—段是 "
"<literal>NOT NULL 的,那么为这一 key å…ƒç´ å®šä¹‰ not-null="
"\"true\"</literal> 是很é‡è¦çš„。ä¸è¦ä»…仅为å¯èƒ½çš„嵌套 <column>not-null=\"true\",<key> "
"is common:"
msgstr "<emphasis>基于外键关è”çš„åŒå‘一对一关è”也很常è§ã€‚ "
#. Tag: para
#, no-c-format
msgid ""
"A <emphasis>bidirectional one-to-one association on a primary key "
"uses the special id generator:"
msgstr ""
"<emphasis>基于主键关è”的一对一关è”需è¦ä½¿ç”¨ç‰¹å®šçš„ id 生æˆå™¨ï¼š"
#. Tag: title
#, no-c-format
msgid "Bidirectional associations with join tables"
msgstr "使用连接表的åŒå‘å…³è”(Bidirectional associations with join tables)"
#. Tag: para
#, no-c-format
msgid ""
"The following is an example of a <emphasis>bidirectional one-to-many "
"association on a join table</emphasis>. The inverse=\"true\"的例åã€‚æ³¨æ„ "
"<literal>inverse=\"true\" å¯ä»¥å‡ºçŽ°åœ¨å…³è”çš„ä»»æ„ä¸€ç«¯ï¼Œå³ collection "
"端或者 join 端。"
#. Tag: title
#, no-c-format
msgid "one to one"
msgstr "一对一(one to one)"
#. Tag: para
#, no-c-format
msgid ""
"A <emphasis>bidirectional one-to-one association on a join table "
"is possible, but extremely unusual."
msgstr ""
"<emphasis>基于连接表的åŒå‘一对一关è”也是å¯è¡Œçš„,但æžä¸ºç½•è§ã€‚"
#. Tag: para
#, no-c-format
msgid ""
"Here is an example of a <emphasis>bidirectional many-to-many association的例å。"
#. Tag: title
#, no-c-format
msgid "More complex association mappings"
msgstr "æ›´å¤æ‚çš„å…³è”æ˜ å°„"
#. Tag: para
#, no-c-format
msgid ""
"More complex association joins are <emphasis>extremely rare. "
"Hibernate handles more complex situations by using SQL fragments embedded in "
"the mapping document. For example, if a table with historical account "
"information data defines <literal>accountNumber, "
"<literal>effectiveEndDate and effectiveStartDate罕è§ã€‚é€šè¿‡åœ¨æ˜ å°„æ–‡æ¡£ä¸åµŒå…¥ SQL 片"
"æ–,Hibernate 也å¯ä»¥å¤„ç†æ›´ä¸ºå¤æ‚的情况。比如,å‡è‹¥åŒ…å«åŽ†å²å¸æˆ·æ•°æ®çš„表定义了 "
"<literal>accountNumberã€effectiveEndDate å’Œ "
"<literal>effectiveStartDate å—段,按照下é¢æ˜ 射:"
#. Tag: para
#, no-c-format
msgid ""
"You can then map an association to the <emphasis>current "
"instance, the one with null <literal>effectiveEndDate, by using:"
msgstr ""
"那么我们å¯ä»¥å¯¹<emphasis>ç›®å‰ï¼ˆcurrent)实例(其 "
"<literal>effectiveEndDate 为 nullï¼‰ä½¿ç”¨è¿™æ ·çš„å…³è”æ˜ å°„ï¼š "
#. Tag: para
#, no-c-format
msgid ""
"In a more complex example, imagine that the association between "
"<literal>Employee and Organization is "
"maintained in an <literal>Employment table full of historical "
"employment data. An association to the employee's <emphasis>most recentstartDate å’Œ OrganizationEmployment ä¸é—´è¡¨ç»´æŠ¤çš„,而"
"ä¸é—´è¡¨ä¸å¡«å……了很多历å²é›‡å‘˜æ•°æ®ã€‚那“雇员的<emphasis>最新雇主â€è¿™ä¸ªå…³"
"è”(最新雇主就是具有最新的 <literal>startDate 的那个)å¯ä»¥è¿™æ ·æ˜ "
"射:"
#. Tag: para
#, no-c-format
msgid ""
"This functionality allows a degree of creativity and flexibility, but it is "
"more practical to handle these kinds of cases using HQL or a criteria query."
msgstr ""
"使用这一功能时å¯ä»¥å……满创æ„å’Œçµæ´»æ€§ï¼Œä½†é€šå¸¸æ›´åŠ 实用的是用 HQL 或æ¡ä»¶æŸ¥è¯¢æ¥å¤„ç†"
"这些情况。"
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<![CDATA["
#~ msgid ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key, addressId "
#~ "bigint not null )\n"
#~ "create table Address ( addressId bigint not null primary key )\n"
#~ " ]]>"
#~ msgstr ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key, addressId "
#~ "bigint not null )\n"
#~ "create table Address ( addressId bigint not null primary key )\n"
#~ " ]]>"
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<![CDATA["
#~ msgid ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key, addressId "
#~ "bigint not null unique )\n"
#~ "create table Address ( addressId bigint not null primary key )\n"
#~ " ]]>"
#~ msgstr ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key, addressId "
#~ "bigint not null unique )\n"
#~ "create table Address ( addressId bigint not null primary key )\n"
#~ " ]]>"
#~ msgid ""
#~ "<![CDATA[\n"
#~ " </generator>\n"
#~ " </id>\n"
#~ " <one-to-one name=\"person\" constrained=\"true\"/>\n"
#~ "</class>]]>"
#~ msgstr ""
#~ "<![CDATA[\n"
#~ " </generator>\n"
#~ " </id>\n"
#~ " <one-to-one name=\"person\" constrained=\"true\"/>\n"
#~ "</class>]]>"
#~ msgid ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key )\n"
#~ "create table Address ( personId bigint not null primary key )\n"
#~ " ]]>"
#~ msgstr ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key )\n"
#~ "create table Address ( personId bigint not null primary key )\n"
#~ " ]]>"
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<![CDATA["
#~ msgid ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key )\n"
#~ "create table Address ( addressId bigint not null primary key, personId "
#~ "bigint not null )\n"
#~ " ]]>"
#~ msgstr ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key )\n"
#~ "create table Address ( addressId bigint not null primary key, personId "
#~ "bigint not null )\n"
#~ " ]]>"
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<![CDATA["
#~ msgid ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key )\n"
#~ "create table PersonAddress ( personId not null, addressId bigint not null "
#~ "primary key )\n"
#~ "create table Address ( addressId bigint not null primary key )\n"
#~ " ]]>"
#~ msgstr ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key )\n"
#~ "create table PersonAddress ( personId not null, addressId bigint not null "
#~ "primary key )\n"
#~ "create table Address ( addressId bigint not null primary key )\n"
#~ " ]]>"
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<![CDATA["
#~ msgid ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key )\n"
#~ "create table PersonAddress ( personId bigint not null primary key, "
#~ "addressId bigint not null )\n"
#~ "create table Address ( addressId bigint not null primary key )\n"
#~ " ]]>"
#~ msgstr ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key )\n"
#~ "create table PersonAddress ( personId bigint not null primary key, "
#~ "addressId bigint not null )\n"
#~ "create table Address ( addressId bigint not null primary key )\n"
#~ " ]]>"
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<![CDATA["
#~ msgid ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key )\n"
#~ "create table PersonAddress ( personId bigint not null primary key, "
#~ "addressId bigint not null unique )\n"
#~ "create table Address ( addressId bigint not null primary key )\n"
#~ " ]]>"
#~ msgstr ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key )\n"
#~ "create table PersonAddress ( personId bigint not null primary key, "
#~ "addressId bigint not null unique )\n"
#~ "create table Address ( addressId bigint not null primary key )\n"
#~ " ]]>"
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<![CDATA["
#~ msgid ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key )\n"
#~ "create table PersonAddress ( personId bigint not null, addressId bigint "
#~ "not null, primary key (personId, addressId) )\n"
#~ "create table Address ( addressId bigint not null primary key )\n"
#~ " ]]>"
#~ msgstr ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key )\n"
#~ "create table PersonAddress ( personId bigint not null, addressId bigint "
#~ "not null, primary key (personId, addressId) )\n"
#~ "create table Address ( addressId bigint not null primary key )\n"
#~ " ]]>"
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<![CDATA["
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<![CDATA["
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<![CDATA["
#~ msgid ""
#~ "<![CDATA[\n"
#~ " </generator>\n"
#~ " </id>\n"
#~ " <one-to-one name=\"person\" \n"
#~ " constrained=\"true\"/>\n"
#~ "</class>]]>"
#~ msgstr ""
#~ "<![CDATA[\n"
#~ " </generator>\n"
#~ " </id>\n"
#~ " <one-to-one name=\"person\" \n"
#~ " constrained=\"true\"/>\n"
#~ "</class>]]>"
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<![CDATA["
#~ msgid ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key )\n"
#~ "create table PersonAddress ( personId bigint not null, addressId bigint "
#~ "not null primary key )\n"
#~ "create table Address ( addressId bigint not null primary key )\n"
#~ " ]]>"
#~ msgstr ""
#~ "<![CDATA[\n"
#~ "create table Person ( personId bigint not null primary key )\n"
#~ "create table PersonAddress ( personId bigint not null, addressId bigint "
#~ "not null primary key )\n"
#~ "create table Address ( addressId bigint not null primary key )\n"
#~ " ]]>"
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<![CDATA["
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<![CDATA["
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<![CDATA["
#~ msgid ""
#~ "<![CDATA[\n"
#~ "</many-to-one>]]>"
#~ msgstr ""
#~ "<![CDATA[\n"
#~ "</many-to-one>]]>"
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<![CDATA["
Other Hibernate examples (source code examples)
Here is a short list of links related to this Hibernate association_mapping.po source code file:
|