|
Hibernate example source code file (example_parentchild.po)
This example Hibernate source code file (example_parentchild.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 example_parentchild.po source code
# translation of Collection_Mapping.po to
# Xi HUANG <xhuang@redhat.com>, 2007, 2010.
msgid ""
msgstr ""
"Project-Id-Version: Collection_Mapping\n"
"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
"POT-Creation-Date: 2010-02-10T07:25:35\n"
"PO-Revision-Date: 2010-01-20 15:29+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 "Example: Parent/Child"
msgstr "例: 親/åä¾›"
#. Tag: para
#, no-c-format
msgid ""
"One of the first things that new users want to do with Hibernate is to model "
"a parent/child type relationship. There are two different approaches to "
"this. The most convenient approach, especially for new users, is to model "
"both <literal>Parent and Child as entity "
"classes with a <literal><one-to-many> association from "
"<literal>Parent to Child. The alternative "
"approach is to declare the <literal>Child as a <"
"composite-element></literal>. The default semantics of a one-to-many "
"association in Hibernate are much less close to the usual semantics of a "
"parent/child relationship than those of a composite element mapping. We will "
"explain how to use a <emphasis>bidirectional one-to-many association with "
"cascades</emphasis> to model a parent/child relationship efficiently and "
"elegantly."
msgstr ""
"æ–°è¦ãƒ¦ãƒ¼ã‚¶ãƒ¼ãŒ Hibernate を使ã£ã¦ã¾ãšæœ€åˆã«æ‰±ã†ãƒ¢ãƒ‡ãƒ«ã®ä¸€ã¤ã«ã€è¦ªååž‹ã®ãƒ¢ãƒ‡ãƒ«"
"化ãŒã‚ã‚Šã¾ã™ã€‚ã“ã®ãƒ¢ãƒ‡ãƒ«åŒ–ã«ã¯äºŒã¤ã®ã‚¢ãƒ—ãƒãƒ¼ãƒãŒå˜åœ¨ã—ã¾ã™ã€‚ã¨ã‚Šã‚ã‘æ–°è¦ãƒ¦ãƒ¼"
"ザーã«ã¨ã£ã¦ã€ã•ã¾ã–ã¾ãªç†ç”±ã‹ã‚‰æœ€ã‚‚便利ã ã¨æ€ã‚れるアプãƒãƒ¼ãƒã¯ã€ <literal>"
"親</literal> ã‹ã‚‰ åä¾› ã¸ã® <one-to-many>親 㨠åä¾› ã®ä¸¡æ–¹ã‚’"
"エンティティクラスã¨ã—ã¦ãƒ¢ãƒ‡ãƒªãƒ³ã‚°ã™ã‚‹æ–¹æ³•ã§ã™ï¼ˆã‚‚ã†ä¸€ã¤ã®æ–¹æ³•ã¯ã€ <literal>"
"åä¾›</literal> ã‚’ <composite-element> ã¨ã—ã¦å®šç¾©ã™ã‚‹"
"ã‚‚ã®ã§ã™ï¼‰ã€‚ã“ã‚Œã§ï¼ˆ Hibernate ã«ãŠã‘る)一対多関連ã®ãƒ‡ãƒ•ã‚©ãƒ«ãƒˆã®ã‚»ãƒžãƒ³ãƒ†ã‚£ã‚¯"
"スãŒã€é€šå¸¸ã®è¤‡åˆè¦ç´ ã®ãƒžãƒƒãƒ”ングよりもã€è¦ªå関係ã®ã‚»ãƒžãƒ³ãƒ†ã‚£ã‚¯ã‚¹ã‹ã‚‰é ã„ã“ã¨"
"ãŒã‚ã‹ã‚Šã¾ã™ã€‚ãã‚Œã§ã¯è¦ªå関係を効率的ã‹ã¤ã‚¨ãƒ¬ã‚¬ãƒ³ãƒˆã«ãƒ¢ãƒ‡ãƒªãƒ³ã‚°ã™ã‚‹ãŸã‚ã«ã€ "
"<emphasis>カスケードæ“作を使ã£ãŸåŒæ–¹å‘一対多関連 ã®æ‰±ã„方を説明ã—"
"ã¾ã™ã€‚ã“ã‚Œã¯ã¾ã£ãŸã難ã—ã„ã‚‚ã®ã§ã¯ã‚ã‚Šã¾ã›ã‚“。"
#. Tag: title
#, no-c-format
msgid "A note about collections"
msgstr "コレクションã«é–¢ã™ã‚‹æ³¨æ„"
#. Tag: para
#, no-c-format
msgid ""
"Hibernate collections are considered to be a logical part of their owning "
"entity and not of the contained entities. Be aware that this is a critical "
"distinction that has the following consequences:"
msgstr ""
"Hibernate ã®ã‚³ãƒ¬ã‚¯ã‚·ãƒ§ãƒ³ã¯è‡ªèº«ã®ã‚¨ãƒ³ãƒ†ã‚£ãƒ†ã‚£ã®è«–ç†çš„ãªéƒ¨åˆ†ã¨è€ƒãˆã‚‰ã‚Œã€æ±ºã—ã¦"
"包å«ã™ã‚‹ã‚¨ãƒ³ãƒ†ã‚£ãƒ†ã‚£ã®ã‚‚ã®ã§ã¯ã‚ã‚Šã¾ã›ã‚“。ã“ã‚Œã¯è‡´å‘½çš„ãªé•ã„ã§ã™ã€‚ã“ã‚Œã¯ä»¥ä¸‹"
"ã®ã‚ˆã†ãªçµæžœã«ãªã‚Šã¾ã™ï¼š"
#. Tag: para
#, no-c-format
msgid ""
"When you remove/add an object from/to a collection, the version number of "
"the collection owner is incremented."
msgstr ""
"オブジェクトをコレクションã‹ã‚‰å‰Šé™¤ã€ã¾ãŸã¯ã‚³ãƒ¬ã‚¯ã‚·ãƒ§ãƒ³ã«è¿½åŠ ã™ã‚‹ã¨ãã€ã‚³ãƒ¬ã‚¯"
"ションã®ã‚ªãƒ¼ãƒŠãƒ¼ã®ãƒãƒ¼ã‚¸ãƒ§ãƒ³ç•ªå·ã¯ã‚¤ãƒ³ã‚¯ãƒªãƒ¡ãƒ³ãƒˆã•ã‚Œã¾ã™ã€‚"
#. Tag: para
#, no-c-format
msgid ""
"If an object that was removed from a collection is an instance of a value "
"type (e.g. a composite element), that object will cease to be persistent and "
"its state will be completely removed from the database. Likewise, adding a "
"value type instance to the collection will cause its state to be immediately "
"persistent."
msgstr ""
"ã‚‚ã—コレクションã‹ã‚‰å‰Šé™¤ã•ã‚ŒãŸã‚ªãƒ–ジェクトãŒå€¤åž‹ã®ã‚¤ãƒ³ã‚¹ã‚¿ãƒ³ã‚¹ï¼ˆä¾‹ãˆã°ã‚³ãƒ³ãƒ"
"ジットエレメント) ã ã£ãŸãªã‚‰ã°ã€ãã®ã‚ªãƒ–ジェクトã¯æ°¸ç¶šçš„ã§ã¯ãªããªã‚Šã€ãã®çŠ¶"
"æ…‹ã¯ãƒ‡ãƒ¼ã‚¿ãƒ™ãƒ¼ã‚¹ã‹ã‚‰å®Œå…¨ã«å‰Šé™¤ã•ã‚Œã¾ã™ã€‚åŒã˜ã‚ˆã†ã«ã€å€¤åž‹ã®ã‚¤ãƒ³ã‚¹ã‚¿ãƒ³ã‚¹ã‚’コレ"
"クションã«è¿½åŠ ã™ã‚‹ã¨ã€ãã®çŠ¶æ…‹ã¯ã™ãã«æ°¸ç¶šçš„ã«ãªã‚Šã¾ã™ã€‚"
#. Tag: para
#, no-c-format
msgid ""
"Conversely, if an entity is removed from a collection (a one-to-many or many-"
"to-many association), it will not be deleted by default. This behavior is "
"completely consistent; a change to the internal state of another entity "
"should not cause the associated entity to vanish. Likewise, adding an entity "
"to a collection does not cause that entity to become persistent, by default."
msgstr ""
"一方ã€ã‚‚ã—エンティティãŒã‚³ãƒ¬ã‚¯ã‚·ãƒ§ãƒ³ï¼ˆä¸€å¯¾å¤šã¾ãŸã¯å¤šå¯¾å¤šé–¢é€£) ã‹ã‚‰å‰Šé™¤ã•ã‚Œã¦"
"ã‚‚ã€ãƒ‡ãƒ•ã‚©ãƒ«ãƒˆã§ã¯ãã‚Œã¯å‰Šé™¤ã•ã‚Œã¾ã›ã‚“。ã“ã®å‹•ä½œã¯å®Œå…¨ã«ä¸€è²«ã—ã¦ã„ã¾ã™ã€‚ã™ãª"
"ã‚ã¡ã€ä»–ã®ã‚¨ãƒ³ãƒ†ã‚£ãƒ†ã‚£ã®å†…部状態を変更ã—ã¦ã‚‚ã€é–¢é€£ã™ã‚‹ã‚¨ãƒ³ãƒ†ã‚£ãƒ†ã‚£ãŒæ¶ˆæ»…ã™ã¹"
"ãã§ã¯ãªã„ã¨ã„ã†ã“ã¨ã§ã™ã€‚åŒæ§˜ã«ã€ã‚¨ãƒ³ãƒ†ã‚£ãƒ†ã‚£ãŒã‚³ãƒ¬ã‚¯ã‚·ãƒ§ãƒ³ã«è¿½åŠ ã•ã‚Œã¦ã‚‚ã€"
"デフォルトã§ã¯ãã®ã‚¨ãƒ³ãƒ†ã‚£ãƒ†ã‚£ã¯æ°¸ç¶šçš„ã«ã¯ãªã‚Šã¾ã›ã‚“。"
#. Tag: para
#, no-c-format
msgid ""
"Adding an entity to a collection, by default, merely creates a link between "
"the two entities. Removing the entity will remove the link. This is "
"appropriate for all sorts of cases. However, it is not appropriate in the "
"case of a parent/child relationship. In this case, the life of the child is "
"bound to the life cycle of the parent."
msgstr ""
"ãã®ä»£ã‚ã‚Šã«ã€ãƒ‡ãƒ•ã‚©ãƒ«ãƒˆã®å‹•ä½œã§ã¯ã€ã‚¨ãƒ³ãƒ†ã‚£ãƒ†ã‚£ã‚’コレクションã«è¿½åŠ ã™ã‚‹ã¨å˜"
"ã«äºŒã¤ã®ã‚¨ãƒ³ãƒ†ã‚£ãƒ†ã‚£é–“ã®ãƒªãƒ³ã‚¯ã‚’作æˆã—ã€ä¸€æ–¹ã‚¨ãƒ³ãƒ†ã‚£ãƒ†ã‚£ã‚’削除ã™ã‚‹ã¨ãƒªãƒ³ã‚¯ã‚‚"
"削除ã—ã¾ã™ã€‚ã“ã‚Œã¯ã™ã¹ã¦ã®ã‚±ãƒ¼ã‚¹ã«ãŠã„ã¦éžå¸¸ã«é©åˆ‡ã§ã™ã€‚ã“ã‚ŒãŒé©åˆ‡ã§ãªã„ã®ã¯"
"親/å関係ã®å ´åˆã§ã™ã€‚ã“ã®å ´åˆåä¾›ã®ç”Ÿå˜ã¯è¦ªã®ãƒ©ã‚¤ãƒ•ã‚µã‚¤ã‚¯ãƒ«ã«åˆ¶é™ã•ã‚Œã‚‹ã‹ã‚‰ã§"
"ã™ã€‚"
#. Tag: title
#, no-c-format
msgid "Bidirectional one-to-many"
msgstr "åŒæ–¹å‘一対多"
#. Tag: para
#, no-c-format
msgid ""
"Suppose we start with a simple <literal><one-to-many> "
"association from <literal>Parent to Child."
msgstr ""
"<literal>Parent ã‹ã‚‰ Child ã¸ã®å˜ç´”㪠"
"<literal><one-to-many> 関連ã‹ã‚‰å§‹ã‚ã‚‹ã¨ã—ã¾ã™ã€‚"
#. Tag: para
#, no-c-format
msgid "If we were to execute the following code:"
msgstr "以下ã®ã‚³ãƒ¼ãƒ‰ã‚’実行ã™ã‚‹ã¨ã€"
#. Tag: para
#, no-c-format
msgid "Hibernate would issue two SQL statements:"
msgstr "Hibernate ã¯äºŒã¤ã® SQL 文を発行ã—ã¾ã™:"
#. Tag: para
#, no-c-format
msgid ""
"an <literal>INSERT to create the record for c"
msgstr ""
"<literal>c ã«å¯¾ã™ã‚‹ãƒ¬ã‚³ãƒ¼ãƒ‰ã‚’生æˆã™ã‚‹ INSERT"
#. Tag: para
#, no-c-format
msgid ""
"an <literal>UPDATE to create the link from p to "
"<literal>c"
msgstr ""
"<literal>p ã‹ã‚‰ c ã¸ã®ãƒªãƒ³ã‚¯ã‚’作æˆã™ã‚‹ "
"<literal>UPDATE"
#. Tag: para
#, no-c-format
msgid ""
"This is not only inefficient, but also violates any <literal>NOT NULLparent_id column. You can fix "
"the nullability constraint violation by specifying <literal>not-null=\"true"
"\"</literal> in the collection mapping:"
msgstr ""
"ã“ã‚Œã¯éžåŠ¹çŽ‡çš„ãªã ã‘ã§ã¯ãªã〠<literal>parent_id カラムã«ãŠã„㦠"
"<literal>NOT NULL 制約ã«é•åã—ã¾ã™ã€‚コレクションã®ãƒžãƒƒãƒ”ング㧠"
"<literal>not-null=\"true\" ã¨æŒ‡å®šã™ã‚‹ã“ã¨ã§ã€ null 制約é•åを解決ã™"
"ã‚‹ã“ã¨ãŒã§ãã¾ã™:"
#. Tag: para
#, no-c-format
msgid "However, this is not the recommended solution."
msgstr "ã—ã‹ã—ã“ã®è§£æ±ºç–ã¯æŽ¨å¥¨ã§ãã¾ã›ã‚“。"
#. Tag: para
#, no-c-format
msgid ""
"The underlying cause of this behavior is that the link (the foreign key "
"<literal>parent_id) from p to cChild "
"object and is therefore not created in the <literal>INSERT. The "
"solution is to make the link part of the <literal>Child mapping."
msgstr ""
"ã“ã®å‹•ä½œã®æ ¹æœ¬çš„ãªåŽŸå› ã¯ã€ <literal>p ã‹ã‚‰ c ã¸"
"ã®ãƒªãƒ³ã‚¯ï¼ˆå¤–部ã‚ー <literal>parent_id) 㯠Child "
"オブジェクトã®çŠ¶æ…‹ã®ä¸€éƒ¨ã¨ã¯è€ƒãˆã‚‰ã‚Œãšã€ãã®ãŸã‚ <literal>INSERT ã«"
"よã£ã¦ãƒªãƒ³ã‚¯ãŒç”Ÿæˆã•ã‚Œãªã„ã“ã¨ã§ã™ã€‚ã§ã™ã‹ã‚‰ã€è§£æ±ºç–ã¯ãƒªãƒ³ã‚¯ã‚’ Child マッピン"
"ã‚°ã®ä¸€éƒ¨ã«ã™ã‚‹ã“ã¨ã§ã™ã€‚"
#. Tag: para
#, no-c-format
msgid ""
"You also need to add the <literal>parent property to the "
"<literal>Child class."
msgstr ""
"(ã¾ãŸ <literal>Child クラス㫠parent プãƒãƒ‘ティ"
"ã‚’è¿½åŠ ã™ã‚‹å¿…è¦ãŒã‚ã‚Šã¾ã™ã€‚)"
#. Tag: para
#, no-c-format
msgid ""
"Now that the <literal>Child entity is managing the state of the "
"link, we tell the collection not to update the link. We use the "
"<literal>inverse attribute to do this:"
msgstr ""
"ãã‚Œã§ã¯ <literal>Child エンティティãŒãƒªãƒ³ã‚¯ã®çŠ¶æ…‹ã‚’制御ã™ã‚‹ã‚ˆã†ã«"
"ãªã£ãŸã®ã§ã€ã‚³ãƒ¬ã‚¯ã‚·ãƒ§ãƒ³ãŒãƒªãƒ³ã‚¯ã‚’æ›´æ–°ã—ãªã„よã†ã«ã—ã¾ã—ょã†ã€‚ãã‚Œã«ã¯ "
"<literal>inverse 属性を使ã„ã¾ã™ã€‚"
#. Tag: para
#, no-c-format
msgid "The following code would be used to add a new <literal>Child:"
msgstr ""
"以下ã®ã‚³ãƒ¼ãƒ‰ã‚’使ãˆã°ã€æ–°ã—ã„ <literal>Child ã‚’è¿½åŠ ã™ã‚‹ã“ã¨ãŒã§ãã¾"
"ã™ã€‚"
#. Tag: para
#, no-c-format
msgid "Only one SQL <literal>INSERT would now be issued."
msgstr ""
"ã“ã‚Œã«ã‚ˆã‚Šã€ SQL ã® <literal>INSERT æ–‡ãŒä¸€ã¤ã ã‘ãŒç™ºè¡Œã•ã‚Œã‚‹ã‚ˆã†ã«"
"ãªã‚Šã¾ã—ãŸã€‚"
#. Tag: para
#, no-c-format
msgid ""
"You could also create an <literal>addChild() method of "
"<literal>Parent."
msgstr ""
"ã‚‚ã†å°‘ã—強化ã™ã‚‹ã«ã¯ã€ <literal>Parent ã® addChild() looks like this:"
msgstr "<literal>Child ã‚’è¿½åŠ ã™ã‚‹ã‚³ãƒ¼ãƒ‰ã¯ã“ã®ã‚ˆã†ã«ãªã‚Šã¾ã™ã€‚"
#. Tag: title
#, no-c-format
msgid "Cascading life cycle"
msgstr "ライフサイクルã®ã‚«ã‚¹ã‚±ãƒ¼ãƒ‰"
#. Tag: para
#, no-c-format
msgid ""
"You can address the frustrations of the explicit call to <literal>save() をコールã™ã‚‹ã®ã¯ã¾ã ç…©ã‚ã—ã„ã‚‚ã®ã§ã™ã€‚ã“ã‚Œ"
"をカスケードを使ã£ã¦å¯¾å‡¦ã—ã¾ã™ã€‚"
#. Tag: para
#, no-c-format
msgid "This simplifies the code above to:"
msgstr "ã“ã‚Œã«ã‚ˆã‚Šå…ˆã»ã©ã®ã‚³ãƒ¼ãƒ‰ã‚’ã“ã®ã‚ˆã†ã«å˜ç´”化ã—ã¾ã™"
#. Tag: para
#, no-c-format
msgid ""
"Similarly, we do not need to iterate over the children when saving or "
"deleting a <literal>Parent. The following removes p ã‚’ä¿å˜ã¾ãŸã¯å‰Šé™¤ã™ã‚‹ã¨ãã«ã€å供を一ã¤ä¸€ã¤å–"
"り出ã—ã¦æ‰±ã†å¿…è¦ã¯ã‚ã‚Šã¾ã›ã‚“。以下ã®ã‚³ãƒ¼ãƒ‰ã¯ <literal>p を削除ã—ã€"
"ãã—ã¦ãƒ‡ãƒ¼ã‚¿ãƒ™ãƒ¼ã‚¹ã‹ã‚‰ãã®å供をã™ã¹ã¦å‰Šé™¤ã—ã¾ã™ã€‚"
#. Tag: para
#, no-c-format
msgid "However, the following code:"
msgstr "ã—ã‹ã—ã“ã®ã‚³ãƒ¼ãƒ‰ã¯"
#. Tag: para
#, no-c-format
msgid ""
"will not remove <literal>c from the database. In this case, it "
"will only remove the link to <literal>p and cause a NOT "
"NULL</literal> constraint violation. You need to explicitly delete()"
"</literal> the Child."
msgstr ""
"データベースã‹ã‚‰ <literal>c を削除ã—ã¾ã›ã‚“。 p "
"ã¸ã®ãƒªãƒ³ã‚¯ã‚’削除ã™ã‚‹ï¼ˆãã—ã¦ã“ã®ã‚±ãƒ¼ã‚¹ã§ã¯ <literal>NOT NULL 制約é•"
"åを引ãèµ·ã“ã™ï¼‰ã ã‘ã§ã™ã€‚ <literal>Child ã® delete() cannot exist without its parent. So "
"if we remove a <literal>Child from the collection, we do want it "
"to be deleted. To do this, we must use <literal>cascade=\"all-delete-orphan"
"\"</literal>."
msgstr ""
"今ã“ã®ã‚±ãƒ¼ã‚¹ã§ã¯å®Ÿéš›ã« <literal>Child ãŒè¦ªãªã—ã§ã¯å˜åœ¨ã§ããªã„よã†"
"ã«ãªã‚Šã¾ã—ãŸã€‚ãã®ãŸã‚ã€ã‚‚ã—コレクションã‹ã‚‰ <literal>Child ã‚’å–ã‚Š"
"除ãå ´åˆã€ã“れも削除ã—ã¾ã™ã€‚ãã®ãŸã‚ã«ã¯ <literal>cascade=\"all-delete-orphan"
"\"</literal> を使ã‚ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。"
#. Tag: para
#, no-c-format
msgid ""
"Even though the collection mapping specifies <literal>inverse=\"true\" ã¨æŒ‡å®šã—"
"ã¦ã‚‚ã€ã‚³ãƒ¬ã‚¯ã‚·ãƒ§ãƒ³ã®è¦ç´ ã®ã‚¤ãƒ†ãƒ¬ãƒ¼ã‚·ãƒ§ãƒ³ã«ã‚ˆã£ã¦ã€ä¾ç„¶ã‚«ã‚¹ã‚±ãƒ¼ãƒ‰ãŒå®Ÿè¡Œã•ã‚Œã¾"
"ã™ã€‚ãã®ãŸã‚ã€ã‚‚ã—カスケードã§ã‚ªãƒ–ジェクトをセーブã€å‰Šé™¤ã€æ›´æ–°ã™ã‚‹å¿…è¦ãŒã‚ã‚‹"
"ãªã‚‰ã€ãれをコレクションã«è¿½åŠ ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。å˜ã« <literal>setParent()"
"</literal> を呼ã¶ã ã‘ã§ã¯ä¸å分ã§ã™ã€‚"
#. Tag: title
#, no-c-format
msgid "Cascades and <literal>unsaved-value"
msgstr "カスケード㨠unsaved-value"
#. Tag: para
#, fuzzy, no-c-format
msgid ""
"Suppose we loaded up a <literal>Parent in one Session. The "
"<literal>Parent will contain a collection of children and, since "
"the cascading update is enabled, Hibernate needs to know which children are "
"newly instantiated and which represent existing rows in the database. We "
"will also assume that both <literal>Parent and ChildLongIn Hibernate3, it is no longer "
"necessary to specify an <literal>unsaved-value explicitly. ãŒã€ã‚ã‚‹ Session ã§ãƒãƒ¼ãƒ‰ã•ã‚Œã€ "
"UI ã®ã‚¢ã‚¯ã‚·ãƒ§ãƒ³ã§å¤‰æ›´ãŒåŠ ãˆã‚‰ã‚Œã€ <literal>update() を呼んã§ã“ã®å¤‰"
"æ›´ã‚’æ–°ã—ã„セッションã§æ°¸ç¶šåŒ–ã—ãŸã„ã¨ã—ã¾ã™ã€‚ <literal>Parent ãŒåä¾›"
"ã®ã‚³ãƒ¬ã‚¯ã‚·ãƒ§ãƒ³ã‚’æŒã¡ã€ã‚«ã‚¹ã‚±ãƒ¼ãƒ‰æ›´æ–°ãŒæœ‰åŠ¹ã«ãªã£ã¦ã„ã‚‹ãŸã‚〠Hibernate ã¯ã©ã®"
"åä¾›ãŒæ–°ã—ãインスタンス化ã•ã‚ŒãŸã‹ã€ã©ã‚ŒãŒãƒ‡ãƒ¼ã‚¿ãƒ™ãƒ¼ã‚¹ã®æ—¢å˜ã®è¡Œã«ç›¸å½“ã™ã‚‹ã®"
"ã‹ã‚’知る必è¦ãŒã‚ã‚Šã¾ã™ã€‚ <literal>Parent 㨠ChildLong åž‹ã®è˜åˆ¥ãƒ—ãƒãƒ‘ティを生æˆã—ãŸã¨ã—ã¾"
"ã—ょã†ã€‚ Hibernate ã¯ã©ã®åä¾›ãŒæ–°ã—ã„ã‚‚ã®ã‹ã‚’決定ã™ã‚‹ãŸã‚ã«è˜åˆ¥ãƒ—ãƒãƒ‘ティã®å€¤"
"を使ã„ã¾ã™ (<xref linkend=\"objectstate-saveorupdate\"/> å‚ç…§)。 "
"<emphasis>Hibernate3 ã«ãªã£ã¦ã€æ˜Žç¤ºçš„ã« unsaved-value を指"
"定ã™ã‚‹å¿…è¦ã¯ãªããªã‚Šã¾ã—ãŸã€‚</emphasis>"
#. Tag: para
#, no-c-format
msgid ""
"The following code will update <literal>parent and childnewChild:"
msgstr ""
"以下ã®ã‚³ãƒ¼ãƒ‰ã¯ <literal>parent 㨠child ã‚’æ›´æ–°"
"ã—〠<literal>newChild を挿入ã—ã¾ã™ã€‚"
#. Tag: para
#, no-c-format
msgid ""
"This may be suitable for the case of a generated identifier, but what about "
"assigned identifiers and composite identifiers? This is more difficult, "
"since Hibernate cannot use the identifier property to distinguish between a "
"newly instantiated object, with an identifier assigned by the user, and an "
"object loaded in a previous session. In this case, Hibernate will either use "
"the timestamp or version property, or will actually query the second-level "
"cache or, worst case, the database, to see if the row exists."
msgstr ""
"ã“れらã¯ç”Ÿæˆã•ã‚ŒãŸè˜åˆ¥åã®å ´åˆã«ã¯éžå¸¸ã«è‰¯ã„ã®ã§ã™ãŒã€å‰²ã‚Šå½“ã¦ã‚‰ã‚ŒãŸè˜åˆ¥åã¨"
"複åˆè˜åˆ¥åã®å ´åˆã¯ã©ã†ã§ã—ょã†ã‹ï¼Ÿã“れ㯠Hibernate ãŒã€ï¼ˆãƒ¦ãƒ¼ã‚¶ãƒ¼ã«ã‚ˆã‚Šå‰²ã‚Šå½“"
"ã¦ã‚‰ã‚ŒãŸè˜åˆ¥åã‚’æŒã¤ï¼‰æ–°ã—ãインスタンス化ã•ã‚ŒãŸã‚ªãƒ–ジェクトã¨ã€ä»¥å‰ã® "
"Session ã§ãƒãƒ¼ãƒ‰ã•ã‚ŒãŸã‚ªãƒ–ジェクトを区別ã§ããªã„ãŸã‚ã€ã‚ˆã‚Šé›£ã—ã„ã§ã™ã€‚ã“ã®å ´"
"åˆã€ Hibernate ã¯ã‚¿ã‚¤ãƒ スタンプã‹ãƒãƒ¼ã‚¸ãƒ§ãƒ³ã®ãƒ—ãƒãƒ‘ティã®ã©ã¡ã‚‰ã‹ã‚’使ã†ã‹ã€äºŒ"
"次ã‚ャッシュã«å•ã„åˆã‚ã›ã¾ã™ã€‚最悪ã®å ´åˆã€è¡ŒãŒå˜åœ¨ã™ã‚‹ã‹ã©ã†ã‹ãƒ‡ãƒ¼ã‚¿ãƒ™ãƒ¼ã‚¹ã‚’"
"見ã¾ã™ã€‚"
#. Tag: title
#, no-c-format
msgid "Conclusion"
msgstr "çµè«–"
#. Tag: para
#, no-c-format
msgid ""
"The sections we have just covered can be a bit confusing. However, in "
"practice, it all works out nicely. Most Hibernate applications use the "
"parent/child pattern in many places."
msgstr ""
"ã“ã“ã§ã¯ã‹ãªã‚Šã®é‡ã‚’è¦ç´„ã—ãŸã®ã§ã€æœ€åˆã®é ƒã¯æ··ä¹±ã—ã¦ã„るよã†ã«æ€ã‚れるã‹ã‚‚ã—"
"ã‚Œã¾ã›ã‚“。ã—ã‹ã—実際ã¯ã€ã™ã¹ã¦éžå¸¸ã«è‰¯ã動作ã—ã¾ã™ã€‚ã»ã¨ã‚“ã©ã® Hibernate アプ"
"リケーションã§ã¯ã€å¤šãã®å ´é¢ã§è¦ªåパターンを使用ã—ã¾ã™ã€‚"
#. Tag: para
#, no-c-format
msgid ""
"We mentioned an alternative in the first paragraph. None of the above issues "
"exist in the case of <literal><composite-element> mappings, "
"which have exactly the semantics of a parent/child relationship. "
"Unfortunately, there are two big limitations with composite element classes: "
"composite elements cannot own collections and they should not be the child "
"of any entity other than the unique parent."
msgstr ""
"最åˆã®æ®µè½ã§ä»£æ›¿æ–¹æ³•ã«ã¤ã„ã¦è§¦ã‚Œã¾ã—ãŸã€‚上記ã®ã‚ˆã†ãªå•é¡Œã¯ <literal><"
"composite-element></literal> マッピングã®å ´åˆã¯å˜åœ¨ã›ãšã€ã«ã‚‚ã‹ã‹ã‚らãšã"
"ã‚Œã¯ç¢ºã‹ã«è¦ªå関係ã®ã‚»ãƒžãƒ³ãƒ†ã‚£ã‚¯ã‚¹ã‚’æŒã¡ã¾ã™ã€‚ã—ã‹ã—残念ãªãŒã‚‰ã€è¤‡åˆè¦ç´ クラ"
"スã«ã¯ï¼’ã¤ã®å¤§ããªåˆ¶é™ãŒã‚ã‚Šã¾ã™ï¼š 1ã¤ã¯è¤‡åˆè¦ç´ ã¯ã‚³ãƒ¬ã‚¯ã‚·ãƒ§ãƒ³ã‚’æŒã¤ã“ã¨ãŒã§"
"ããªã„ã“ã¨ã§ã™ã€‚ã‚‚ã†ã²ã¨ã¤ã¯ã€ãƒ¦ãƒ‹ãƒ¼ã‚¯ãªè¦ªã§ã¯ãªã„エンティティã®åä¾›ã¨ãªã‚‹ã¹"
"ãã§ã¯ãªã„ã¨ã„ã†ã“ã¨ã§ã™"
#, fuzzy
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<set name=\"children\">\n"
#~ " <key column=\"parent_id\"/>\n"
#~ " <one-to-many class=\"Child\"/>\n"
#~ "</set>"
#, fuzzy
#~ msgid ""
#~ "<![CDATA[Parent p = .....;\n"
#~ "Child c = new Child();\n"
#~ "p.getChildren().add(c);\n"
#~ "session.save(c);\n"
#~ "session.flush();]]>"
#~ msgstr ""
#~ "Parent p = .....;\n"
#~ "Child c = new Child();\n"
#~ "p.getChildren().add(c);\n"
#~ "session.save(c);\n"
#~ "session.flush();"
#, fuzzy
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<set name=\"children\">\n"
#~ " <key column=\"parent_id\" not-null=\"true\"/>\n"
#~ " <one-to-many class=\"Child\"/>\n"
#~ "</set>"
#, fuzzy
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<many-to-one name=\"parent\" column=\"parent_id\" not-null=\"true\"/"
#~ ">"
#, fuzzy
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<set name=\"children\" inverse=\"true\">\n"
#~ " <key column=\"parent_id\"/>\n"
#~ " <one-to-many class=\"Child\"/>\n"
#~ "</set>"
#, fuzzy
#~ msgid ""
#~ "<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
#~ "Child c = new Child();\n"
#~ "c.setParent(p);\n"
#~ "p.getChildren().add(c);\n"
#~ "session.save(c);\n"
#~ "session.flush();]]>"
#~ msgstr ""
#~ "Parent p = (Parent) session.load(Parent.class, pid);\n"
#~ "Child c = new Child();\n"
#~ "c.setParent(p);\n"
#~ "p.getChildren().add(c);\n"
#~ "session.save(c);\n"
#~ "session.flush();"
#, fuzzy
#~ msgid ""
#~ "<![CDATA[public void addChild(Child c) {\n"
#~ " c.setParent(this);\n"
#~ " children.add(c);\n"
#~ "}]]>"
#~ msgstr ""
#~ "public void addChild(Child c) {\n"
#~ " c.setParent(this);\n"
#~ " children.add(c);\n"
#~ "}"
#, fuzzy
#~ msgid ""
#~ "<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
#~ "Child c = new Child();\n"
#~ "p.addChild(c);\n"
#~ "session.save(c);\n"
#~ "session.flush();]]>"
#~ msgstr ""
#~ "Parent p = (Parent) session.load(Parent.class, pid);\n"
#~ "Child c = new Child();\n"
#~ "p.addChild(c);\n"
#~ "session.save(c);\n"
#~ "session.flush();"
#, fuzzy
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<set name=\"children\" inverse=\"true\" cascade=\"all\">\n"
#~ " <key column=\"parent_id\"/>\n"
#~ " <one-to-many class=\"Child\"/>\n"
#~ "</set>"
#, fuzzy
#~ msgid ""
#~ "<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
#~ "Child c = new Child();\n"
#~ "p.addChild(c);\n"
#~ "session.flush();]]>"
#~ msgstr ""
#~ "Parent p = (Parent) session.load(Parent.class, pid);\n"
#~ "Child c = new Child();\n"
#~ "p.addChild(c);\n"
#~ "session.flush();"
#, fuzzy
#~ msgid ""
#~ "<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
#~ "session.delete(p);\n"
#~ "session.flush();]]>"
#~ msgstr ""
#~ "Parent p = (Parent) session.load(Parent.class, pid);\n"
#~ "session.delete(p);\n"
#~ "session.flush();"
#, fuzzy
#~ msgid ""
#~ "<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
#~ "Child c = (Child) p.getChildren().iterator().next();\n"
#~ "p.getChildren().remove(c);\n"
#~ "c.setParent(null);\n"
#~ "session.flush();]]>"
#~ msgstr ""
#~ "Parent p = (Parent) session.load(Parent.class, pid);\n"
#~ "Child c = (Child) p.getChildren().iterator().next();\n"
#~ "p.getChildren().remove(c);\n"
#~ "c.setParent(null);\n"
#~ "session.flush();"
#, fuzzy
#~ msgid ""
#~ "<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
#~ "Child c = (Child) p.getChildren().iterator().next();\n"
#~ "p.getChildren().remove(c);\n"
#~ "session.delete(c);\n"
#~ "session.flush();]]>"
#~ msgstr ""
#~ "Parent p = (Parent) session.load(Parent.class, pid);\n"
#~ "Child c = (Child) p.getChildren().iterator().next();\n"
#~ "p.getChildren().remove(c);\n"
#~ "session.delete(c);\n"
#~ "session.flush();"
#, fuzzy
#~ msgid ""
#~ "<![CDATA["
#~ msgstr ""
#~ "<set name=\"children\" inverse=\"true\" cascade=\"all-delete-orphan"
#~ "\">\n"
#~ " <key column=\"parent_id\"/>\n"
#~ " <one-to-many class=\"Child\"/>\n"
#~ "</set>"
#, fuzzy
#~ msgid ""
#~ "<![CDATA[//parent and child were both loaded in a previous session\n"
#~ "parent.addChild(child);\n"
#~ "Child newChild = new Child();\n"
#~ "parent.addChild(newChild);\n"
#~ "session.update(parent);\n"
#~ "session.flush();]]>"
#~ msgstr ""
#~ "//parent and child were both loaded in a previous session\n"
#~ "parent.addChild(child);\n"
#~ "Child newChild = new Child();\n"
#~ "parent.addChild(newChild);\n"
#~ "session.update(parent);\n"
#~ "session.flush();"
Other Hibernate examples (source code examples)
Here is a short list of links related to this Hibernate example_parentchild.po source code file:
|